在带有DQL的WHERE子句中使用DATE()函数

时间:2012-11-07 14:58:11

标签: doctrine doctrine-orm dql

执行此DQL查询时出现奇怪的错误:

SELECT u FROM User u LEFT JOIN u.schedule s WHERE DATE(s.timestamp) = DATE(NOW())

Doctrine抛出了异常消息:

Expected known function, got 'DATE'

该问题看起来类似于this bug,但它解决了GROUP BY子句中的DATE()函数问题,并且Doctrine 2.2的错误已关闭。此时,我得到了doctrine 2.4-DEV的例外。

该查询旨在选择今天安排的所有用户。有什么方法可以创建这个DQL吗?我在phpMyAdmin中测试了SQL版本,并且查询不会引发错误。什么可能是错的?

1 个答案:

答案 0 :(得分:31)

您可以使用custom function

来实现您的目标
use Doctrine\ORM\Query\AST\Functions\FunctionNode;
use Doctrine\ORM\Query\Lexer;
use Doctrine\ORM\Query\SqlWalker;
use Doctrine\ORM\Query\Parser;

class DateFunction extends FunctionNode
{
    private $arg;

    public function getSql(SqlWalker $sqlWalker)
    {
        return sprintf('DATE(%s)', $this->arg->dispatch($sqlWalker));
    }

    public function parse(Parser $parser)
    {
        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);

        $this->arg = $parser->ArithmeticPrimary();

        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
    }
}

然后在您的代码中注册此功能:

$em->getConfiguration()->addCustomDatetimeFunction('DATE', 'DateFunction');

您的DQL查询将有效!