「場所」と呼ばれるネストされたセット (Gedmo ツリーを使用) エンティティがあります。エンティティ「アパート」にはlocation_idがあり、「パス」などと呼ばれるスカラー値をすべてのアパートを返すクエリにマップするために必要なものがあります。
Doctrine1 には、次のコードがありました。
/**
* Add "path" to each element
*
* @param Doctrine_Query $query
* @param string $separator
*/
protected function addScalar_path(Doctrine_Query $query, $separator=", ")
{
$subquery = "k99.root_id=o.root_id AND k99.lft<=o.lft AND k99.rgt>=o.rgt AND k99.level<=o.level" ;
$query->addSelect("(SELECT GROUP_CONCAT(k99.name ORDER BY k99.level SEPARATOR '$separator') FROM Location k99 WHERE $subquery) AS path") ;
}
注: "o" エイリアスはプライマリ クエリに使用されます。このコードを使用すると、
{foreach .... as $appartment}
{$appartment->path}
...
どちらが印刷されますか:
Australia, Victoria, Melbourne, ...other children...
D2で同じことをする方法は? また、私の symfony2 プロジェクトにドクトリン拡張を含めるにはどうすればよいでしょうか?