我执行此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已关闭。这时,我对准则2.4-DEV有了例外。

该查询旨在选择今天计划的所有用户。有什么办法可以创建此DQL?我在phpMyAdmin中测试了SQL版本,那里的查询没有引发错误。有什么问题吗?

最佳答案

您可以使用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查询将起作用!

关于doctrine - 在带有DQL的WHERE子句中使用DATE()函数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13272224/

10-13 06:11