我有一个实体,看起来像这样:
/**
* @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 字段。我尝试了很多变化,即使我像这样做:
SELECT t1.parent_id FROM my_table t1 WHERE ...
$qb = $this->em->createQueryBuilder()
->select('c')
->from('Category', 'c');
我可以获取表中除了parent_id字段的所有字段。这似乎是Doctrine在干扰我的操作。我如何查询parent_id字段?或者更好的方法是,如何获取表中所有字段,包括parent_id?
$query->getResult(\Doctrine\ORM\Query::HYDRATE_OBJECT);
(默认参数)显然被身份函数覆盖。 - eggmatters$qb->select('identity(c.parent)')
。 - scyrma