首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查询参考文档ODM Doctrine2

查询参考文档ODM Doctrine2
EN

Stack Overflow用户
提问于 2013-12-07 02:06:53
回答 1查看 237关注 0票数 0

我有两个文档CarDriver

代码语言:javascript
复制
/**
* @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;

    //...
}

我想要一辆“彼得”开的车

代码语言:javascript
复制
$car = $dm
  ->getRepository('Car')
  ->createQueryBuilder()
  ->field('driver.name')->equals("Peter")
  ->getQuery()->getSingleResult();

但是,即使数据库中存在CarDriver,前面的代码也会返回NULL

我找到了一个similar question,我想知道这个缺点是否可以用其他方法解决

EN

回答 1

Stack Overflow用户

发布于 2013-12-09 23:30:07

尝尝这个

代码语言:javascript
复制
$car = $dm
->getRepository('Car')
->createQueryBuilder()
->where('driver.name =?1')
->setParameter(1, 'Peter')
->getQuery()->getSingleResult();

编辑:

如果司机Peter有不止一辆车,你应该使用->getOneOrNullResult()而不是getSingleResult()

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20430662

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档