简体   繁体   English

查询参考文档ODM Doctrine2

[英]Query reference documents ODM Doctrine2

I have two documents Car and Driver 我有两个文件CarDriver

/**
* @ODM\Document(collection="cars")
*/
class Car { 
    /**
     * @ODM\Id
     */
    protected $id;

    /**
     * @ODM\ReferenceOne(targetDocument="Driver")
     */
    protected $driver;

    //...
}

/**
* @ODM\Document(collection="drivers")
*/
class Driver { 
    /**
     * @ODM\Id
     */
    protected $id;

    /**
     * @ODM\String
     * @Assert\NotBlank()
     */
    protected $name;

    //...
}

I want one car driven by "Peter" 我想要一辆由“彼得”驾驶的汽车

$car = $dm
  ->getRepository('Car')
  ->createQueryBuilder()
  ->field('driver.name')->equals("Peter")
  ->getQuery()->getSingleResult();

but the previous code return NULL even if the Car and the Driver exist in the database 但是即使数据库中存在CarDriver ,先前的代码也会返回NULL

I found a similar question i want to know if this drawback can be solved by other way 我发现了一个类似的问题,我想知道是否可以通过其他方式解决此缺陷

Try this 尝试这个

$car = $dm
->getRepository('Car')
->createQueryBuilder()
->where('driver.name =?1')
->setParameter(1, 'Peter')
->getQuery()->getSingleResult();

EDIT : 编辑:

If the driver Peter has more then one Car, you should use ->getOneOrNullResult() instead of getSingleResult() 如果驾驶员彼得有一辆以上的汽车,则应使用->getOneOrNullResult()而不是getSingleResult()

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM