2012-09-24 93 views
3

在我的'主题'实体中,我有一对多自引用关系$parent:$childrenDoctrine2一对多,自我引用关系

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' 

回答

5

的问题是,选择具有相同名称(从主题名称字段,并从孩子的名字字段)两个字段。这些名称在创建数组键时相互冲突。这个问题的解决方案是通过重命名其中一个字段:

SELECT t.name, c.name AS child_name FROM My\xxxBundle\Entity\Topic t 

你得到一个平坦的阵列究其原因,是因为你没有选择的实体,而是由这些实体单独的值。

更多信息请参见该DQL文件: http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/reference/dql-doctrine-query-language.html#select-queries

编辑 目前的结果你从查询得到的是合乎逻辑的。它与您在运行等效SQL查询时获得的结果相匹配。您目前正在做的是从两个数据库表中获取两个值。你真正想要的是在数组中格式化的两个部分实体。

你可以尝试的是使用Partials。这是一种在学说中选择一个实体的几个字段的方法。你把它与 - > getArrayResult()结合起来,你可能得到正确的输出

return $this->getEntityManager()->createQuery(' 
    SELECT partial t.{name}, partial c.{name} 
    FROM My\xxxBundle\Entity\Topic t 
    LEFT JOIN t.children c 
    WHERE t.parent IS NULL 
') 
->getArrayResult(); 
+0

我仍然得到错误的数组格式。我编辑了我的问题以添加更多结果 – qais

+1

尝试按我在编辑的答案中描述的部分 – Mark

+0

现在可以使用。谢谢马克 – qais