我有两个文档Car和Driver
/**
* @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;
//...
}我想要一辆“彼得”开的车
$car = $dm
->getRepository('Car')
->createQueryBuilder()
->field('driver.name')->equals("Peter")
->getQuery()->getSingleResult();但是,即使数据库中存在Car和Driver,前面的代码也会返回NULL
我找到了一个similar question,我想知道这个缺点是否可以用其他方法解决
发布于 2013-12-09 23:30:07
尝尝这个
$car = $dm
->getRepository('Car')
->createQueryBuilder()
->where('driver.name =?1')
->setParameter(1, 'Peter')
->getQuery()->getSingleResult();编辑:
如果司机Peter有不止一辆车,你应该使用->getOneOrNullResult()而不是getSingleResult()
https://stackoverflow.com/questions/20430662
复制相似问题