1. ホーム
  2. symfony

[解決済み] Symfony2 と Doctrine - Error: Invalid PathExpression. StateFieldPathExpressionでなければなりません。

2022-12-21 09:38:39

質問

次のようなエンティティがあります。

/**
 * @Gedmo\Tree(type="nested")
 * @ORM\Table(name="categories")
 * @ORM\Entity()
 */
class Category extends BaseCategory
{

    /**
    * @ORM\OneToMany(targetEntity="Category", mappedBy="parent")
    */
    protected $children;

    /**
    * @Gedmo\TreeParent
    * @ORM\ManyToOne(targetEntity="Category", inversedBy="children")
    * @ORM\JoinColumn(name="parent_id", referencedColumnName="id", onDelete="SET NULL")
    */
    protected $parent;

}

と、このようなクエリを実行しようとしています。

$qb = $this->em->createQueryBuilder()
            ->select('c.parent')
            ->from('Category', 'c');

$result = $qb->getQuery()->getArrayResult();

しかし、以下のようなエラーが発生します。

[Semantical Error] ... Error: Invalid PathExpression. Must be a StateFieldPathExpression. 

テーブルから parent_id フィールドを選択するにはどうしたらよいでしょうか。私はたくさんのバリエーションを試しましたが、このようなことをしても。

$qb = $this->em->createQueryBuilder()
            ->select('c')
            ->from('Category', 'c');

テーブルのすべてのフィールドを取得する を除く を除くすべてのフィールドを取得します。これは Doctrine が邪魔をしているように思えます。この parent_id フィールドをクエリするにはどうすればよいのでしょうか? すべて フィールドを含むテーブルの parent_id

どのように解決するのですか?

現在文書化されていない IDENTITY 関数を使用して、クエリ内の FK ID を選択することができます。

SELECT IDENTITY(c.parent) ...