在使用DQL的WHERE子句中使用date()函数



我执行此DQL查询时会遇到一个奇怪的错误:

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

例外是通过传递消息抛出的:

Expected known function, got 'DATE'

这个问题看起来与此错误相似,但是该问题解决了组中的date()函数,并且对于学说2.2,该错误已关闭。目前,我得到了学说2.4-dev的例外。

查询旨在选择今天安排的所有用户。有什么办法可以创建此DQL?我在phpmyadmin中测试了SQL版本,那里的查询不会引起错误。可能怎么了?

您可以使用自定义功能来实现所需的目标:

use DoctrineORMQueryASTFunctionsFunctionNode;
use DoctrineORMQueryLexer;
use DoctrineORMQuerySqlWalker;
use DoctrineORMQueryParser;
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查询将起作用!

相关内容

  • 没有找到相关文章

最新更新