0

我有一个 symfony 问题:功能上运行良好,但这不能按我想要的方式运行。

$res = array("4","2","1","3"); // LIST ID (a.id)
$paginas = new sfDoctrinePager('TbArticle', 2);
$paginas->setQuery(Doctrine::getTable('TbArticle')->createQuery('a')->where('a.ifactive = 1')->andWhere('a.dirimage=1')->andWhere('a.stock<>0')->whereIn("a.id", $res));
$paginas->setPage($page);
$paginas->init();

它工作正常,但是当我调用时getResults(),数组顺序不正确。例如,这种排序返回:1,2,3,4. 我喜欢得到4, 2, 1, 3:($res

你能帮助我吗?

4

1 回答 1

1

不幸的是,这不能通过查询来完成。

ORDER BY可以使用子句按升序或降序顺序返回 MySQL 查询。数组中的元素不使用。当您将数组作为WHERE IN子句的参数传递时,MySQL 并不关心元素的顺序,如您所见。

幸运的是有一个解决方案:)

首先,您必须使用 Doctrine 的能力来创建一个结果表,并用您想要的内容进行索引。用这个:

Doctrine::getTable('TbArticle')->createQuery('a INDEX BY id')->...;

这将返回一个结果数组,其中数组键是行的 id。然后您可以重新排列结果数组以匹配您的$res(假设$rows有 Doctrine 返回的行):

foreach ($res as $i) {
    $new_array[] = $rows[$i];
}

棘手的部分是让它与分页器一起工作。但我相信你也可以这样做(尝试从分页器中检索结果并在显示之前重新排列它们)。

于 2013-03-28T18:15:05.730 回答