7

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)')));

「images」フィールドに両方の記事の画像が含まれる 1 行のみが返されます。

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

ここで何が間違っていますか?

4

1 に答える 1

9

group byクエリで節を使用していません。

以下を試してください:

$select->from(array('a'=>'articles'))
  ->joinLeft(
       array('i'=>'images'),
       'i.article_id=a.id',
       array('images'=> new Zend_Db_Expr('GROUP_CONCAT(i.image)')))
  ->group('a.id');
于 2012-04-10T09:41:18.393 に答える