假设我们有一个类似这样的查询:
SELECT *, (CUSTOM_EXPRESSION) as virtualfield FROM users
用户实体本身具有“虚拟字段”,但映射注释没有,因为表没有此字段。
假设它是作为原始SQL执行的,我们如何用上面的字段填充实体?
我找到了答案。为此,您需要使用标量值。例如:
$rsm = new \Doctrine\ORM\Query\ResultSetMappingBuilder($this->getEntityManager()); $rsm->addRootEntityFromClassMetadata('Category', 'c'); $rsm->addScalarResult('depth', 'depth'); // [ ... ] $results = $q->execute(); // Output will be a two-dimensional array // array(0 => array(0 => CategoryObject, 'depth' => 'scalar-value', // ... ), // ...)
然后,您可以遍历它,并根据需要在对象上设置属性。