我有一个实体如下:
private $username;
private $password;
private $createdAt; //datetime
我想在doctrine中运行查询以获取具有现有字段和另一个字段的实体(在这种情况下,列显示createdAt和当前日期时间的差异,以分钟为单位)。 在sql中我会运行如下查询:
select username, password, createdAt,TIMESTAMPDIFF(MINUTE , created_at, NOW()) AS minutes from users
在学说中我获取了如下实体:
$user = $em->getRepository('TestBundle:Users');
如何从教条中获取自定义字段分钟?
答案 0 :(得分:5)
您应该检查ResultSetMapping:
并查看如何添加scalar result
$rsm = new ResultSetMapping;
$rsm->addEntityResult('Users', 'u');
$rsm->addFieldResult('u', 'id', 'id');
$rsm->addFieldResult('u', 'password', 'password');
$rsm->addScalarResult('minutes', 'minutes');
$query = $this->_em->createNativeQuery('select username, password, TIMESTAMPDIFF(MINUTE , created_at, NOW()) AS minutes', $rsm);
$users = $query->getResult();
答案 1 :(得分:1)
您可以在实体中设置功能,如
function GetDifference() {
return getField1() - getField2()
}
然后,每个对象都可以使用
编辑: 它很容易。就像任何其他功能一样
function getDateDifference() {
return abs(strtotime($createdAT) - strtotime($now));
}