GROUP_CONCAT с JOINLEFT в Zend Db Select

Предполагая, что у меня есть 2 таблицы

articles
  id              title
  1               Article 1
  2               Article 2


Images
  id              article_id     image
  1               1              a.png
  2               1              b.png
  3               2              c.png
  4               2              d.png

Все, что я хочу, это получить все статьи с их изображениями.

Например:

article_id     title           images
1              Article 1       a.png, b.png
2              Article 2       c.png, d.png

Как я могу сделать это с помощью Zend_Db_Select?

Я пробовал что-то вроде этого, но не повезло:

$select = $this->getDbTable()->select()->setIntegrityCheck(false)->distinct();
$select->from(array('a'=>'articles'))
  ->joinLeft(array('i'=>'images'),'i.article_id=a.id',array('images'=> new
               Zend_Db_Expr('GROUP_CONCAT(i.image)')));

Он возвращает только 1 строку, поле «images» которой содержит изображения обеих статей.

article_id     title           images
1              Article 1       a.png, b.png, c.png, d.png

Что я здесь делаю не так?

7
задан dgw 10 April 2012 в 09:35
поделиться