0

ここに私の(簡略化された)カテゴリエンティティがあります:

/**
 * @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 ではもちろん非常に単純ですが、Doctrine では結合テーブルは透過的に見えます。

4

1 に答える 1

0

参照のみが必要な場合は、便利な getReference() メソッドがあり、次のように使用します。

$item = $this->em->getReference('Entity\Item', $id);

または、関連付けられたエンティティを EXTRA_LAZY に設定することもできます。それはすべて、正確に何が必要かによって異なりますが、これらはオーバーヘッドを削減するための 2 つのアプローチです。

于 2013-02-18T23:21:26.063 に答える