在我的'主题'实体中,我有一对多自引用关系$parent:$children
。Doctrine2一对多,自我引用关系
class Topic
{
/** @ORM\Id
* @Column(type="integer")
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/** @Column(length=40, unique=true) */
private $name;
/**
* @ORM\ManyToOne(targetEntity="Topic", inversedBy="children")
*/
private $parent;
/**
* @ORM\OneToMany(targetEntity="Topic", mappedBy="parent")
*/
private $children;
}
我可以加入该表到拿到父子层次结构是这样的:
return $this->getEntityManager()->createQuery('
SELECT t, c FROM My\xxxBundle\Entity\Topic t
LEFT JOIN t.children c
WHERE t.parent IS NULL
')
->getArrayResult();
这里是正确的输出:
array
0 =>
array
'id' => int 1
'name' => string 'Parent 1'
'slug' => string 'p-1'
'description' => null
'children' =>
array
0 =>
array
'id' => int 2
'name' => string 'Child 1-1'
'slug' => string 'c-1-1'
'description' => null
1 =>
array
'id' => int 3
'name' => string 'Child 1-2'
'slug' => string 'c-1-2'
'description' => null
1 =>
array
'id' => int 4
'name' => string 'Parent 2'
'slug' => string 'p-2'
'description' => null
'children' =>
array
empty
...
,但如果我尝试获取特定列SELECT语句:
SELECT t.name, c.name FROM My\xxxBundle\Entity\Topic t
我得到一个扁平的子实体,即只有c.name
。如果父母有没有孩子,我只是得到了它的名字空值:
1 =>
array (size=1)
'name' => string 'Child 1-1' (length=14)
2 =>
array (size=1)
'name' => string 'Child 1-2' (length=14)
3 =>
array (size=1)
'name' => null
4 =>
array (size=1)
'name' => string 'Child 3-1' (length=5)
马克的建议,我已经改名为孩子实体的名称字段:
SELECT t.name, c.name AS child_name FROM My\xxxBundle\Entity\Topic t
,但我仍然得到错误的格式:
array
0 =>
array
'name' => string 'Parent 1'
'child_name' => string 'Child 1-1'
1 =>
array
'name' => string 'Parent 1'
'child_name' => string 'Child 1-2'
2 =>
array
'name' => string 'Parent 2'
'child_name' => string 'Child 2-1'
我仍然得到错误的数组格式。我编辑了我的问题以添加更多结果 – qais
尝试按我在编辑的答案中描述的部分 – Mark
现在可以使用。谢谢马克 – qais