私のカテゴリ用のテーブルがあり、各カテゴリにはid、name、およびparent_idがあります。MySQLをDoctrine Query Builderに変換する。 IFとCONCATの問題選択時のサブクエリの別のアプローチ
Select IF(a.parent_id IS NULL, a.name, CONCAT((SELECT b.name FROM category b WHERE b.id = a.parent_id), "/", a.name)) as n, a.id, a.parent_id
FROM category a
ORDER BY n
私は私のDoctrine2クエリビルダにそのような
$em = $this->getDoctrine()->getEntityManager();
$qb = $em->createQueryBuilder();
$q = $qb
->select("c.id")
->addSelect(
"IF(c.parent_id IS NULL, c.name, CONCAT((" .
$em->createQueryBuilder()
->select("t.name")
->from("MyBundle:Category", "t")
->getQuery()->getDQL() .
"), \"/\", c.name))"
)
->from("MyBundle:Category", "c");
echo $q->getQuery()->getSQL();
exit;
何かを、それを変換したいが、私はIF
、およびCONCAT
を使用傾けます。
symfonyの最新バージョン - dqlノードはentity_managerの下にある必要があります – Harold
Fantastic!それは働いた、ケースステートメント。 –