这是我的(简化)类别实体:
/**
* @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查询,它会为每个类别提供一个结果:
在SQL中它当然非常简单,但是在Doctrine中连接表似乎是透明的。
答案 0 :(得分:0)
如果你只需要引用,有一个方便的getReference()方法,使用如下:
$item = $this->em->getReference('Entity\Item', $id);
或者,您可以将关联的实体设置为EXTRA_LAZY。这一切都取决于你究竟需要什么,但这是减少开销的两种方法。