2

我有一个类似的查询:

$em->createQuery(
    'SELECT t FROM myTestBundle:User t WHERE t.userId = :username AND
    t.tokenCreatedtime > (NOW() - INTERVAL 800 MINUTE)'
);

(NOW() - INTERVAL 800 MINUTE)不在 DQL 中工作。还有其他方法可以实现吗?

4

1 回答 1

3

我建议您创建一个占位符并传递DateTime对象

$q = $em->createQuery(
    'SELECT t FROM myTestBundle:User t WHERE t.userId = :username AND
    t.tokenCreatedtime > :createdTime '
);
$q->setParameter(':createdTime',new \DateTime("-800 minute")

此外,您可能希望将\DateTime对象创建为new \DateTime("-800 minute")

于 2013-03-07T12:28:15.273 回答