orderBy和; group按查询

时间:2012-07-22 16:19:44

标签: mysql doctrine symfony-1.4 doctrine-1.2 doctrine-query

我的数据库条目

id | shop_id | last_changed
1  |     1   |   7 pm
2  |     1   |   8 pm
3  |     2   |   9 pm
4  |     2   |   8 pm
5  |     3   |   5 pm

我的查询应该是我只获得带有id的条目:

2, 3, 5 

当我这样做时:

$q = Doctrine_Query::create()
         ->from('list e')
         ->groupBy('e.shopname_id')
         ->orderBy('e.last_changed DESC')
         ->limit(6)
         ->fetchArray();

我得到:1, 4, 5。即使我e.last_changed ASC,它也不起作用。

我只想要那些拥有last_changed和不同shop_id的人。我该怎么办?

谢谢!

1 个答案:

答案 0 :(得分:2)

试试这个:

$q = Doctrine_Query::create()
        ->select('e.shopname_id, MAX(e.id) AS id, MAX(e.last_changed) AS last_changed')
        ->from('list e')
        ->groupBy('e.shopname_id')
        ->orderBy('MAX(e.last_changed) DESC')
        ->limit(6)
        ->fetchArray();