Doctrine orm 访问Doctrine2中的联接表字段
以下是我的(简化)类别实体:Doctrine orm 访问Doctrine2中的联接表字段,doctrine-orm,jointable,Doctrine Orm,Jointable,以下是我的(简化)类别实体: /** * @ORM\Entity */ class Category { /** * @ORM\Id * @ORM\Column(type="integer") * @ORM\GeneratedValue(strategy="AUTO") */ protected $id = null; /** * @ORM\ManyToOne(targetEntity="Category",
/**
* @ORM\Entity
*/
class Category
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id = null;
/**
* @ORM\ManyToOne(targetEntity="Category", inversedBy="children", fetch="EAGER")
*/
protected $parent = null;
/**
* @ORM\OneToMany(targetEntity="Category", mappedBy="parent", fetch="LAZY")
* @ORM\JoinTable(name="category_tree",
* joinColumns={@ORM\JoinColumn(name="parent_id", referencedColumnName="id")},
* inverseJoinColumns={@ORM\JoinColumn(name="child_id", referencedColumnName="id")}
* )
*/
protected $children;
}
我是否可以编写一个DQL查询,为每个类别提供一个结果:
- 它的id
- 一个包含其子项ID的数组
在SQL中,这当然非常简单,但联接表在原则上似乎是透明的。如果您只需要引用,有一个方便的getReference()方法,如下所示:
$item = $this->em->getReference('Entity\Item', $id);
或者,您可以将关联的实体设置为EXTRA_LAZY。这完全取决于您需要什么,但这是两种减少开销的方法。这在DQL中不起作用。在DQL中,您最终可以获取连接相关项,因为我已经在进行获取连接,但是由于我只需要获取连接表和主表的ID,所以我愿意节省大量开销。那么我将继续使用fetch连接。非常感谢。