Doctrine querybuilder DATE_FORMAT无效

时间:2014-10-10 11:17:10

标签: php mysql date symfony doctrine-orm

我在createQueryBuilder中遇到了DATE_FORMAT的问题

我的代码:

$qb7Days = $repo->createQueryBuilder('R')
        ->select( 'R.createdAt' )
        ->where( "DATE_FORMAT(R.createdAt, '%Y-%m-%d') = :afterDays" )
        ->andWhere( 'R.cCurrentReviewState = :state' )
        ->andWhere( 'R.reminder = :reminder' )
        ->setParameter( 'afterDays', $after7Days )
        ->setParameter( 'state',  $oReviewStateNotVerified ) // not_verified
        ->setParameter( 'reminder',  0 ) // never sent any reminder
        ->orderBy( 'R.id', 'ASC' )
        ->getQuery();

但我得到了

 [Doctrine\ORM\Query\QueryException]                                              
 [Syntax Error] line 0, col 7: Error: Expected known function, got 'DATE_FORMAT'

我搜索了一些链接并找到了一些解释,它应该以这种方式工作,但对我来说,它看起来像我做错了。

http://www.uvd.co.uk/blog/labs/using-mysqls-date_format-in-doctrine-2-0/

5 个答案:

答案 0 :(得分:18)

DATE_FORMAT以及一堆Mysql函数在Doctrine中无法直接使用。

要使用它们,您可以创建自己的扩展程序,也可以添加beberlei/DoctrineExtensions之类的扩展名,然后将相应的功能添加到您的学说包配置中,如

doctrine:
    dbal:
        ....
    orm:
        ....
        dql:
            string_functions:
                DATE_FORMAT: DoctrineExtensions\Query\Mysql\DateFormat

答案 1 :(得分:1)

DATE_FORMAT不是学说认可的功能。您粘贴的链接是作者为他写的自定义代码以获取date_formate。你可以在学说中编写自定义函数并注册它们,整洁吗?

以下是如何执行此操作的示例 - http://symfony.com/doc/current/cookbook/doctrine/custom_dql_functions.html

选项1:您为DATE_FORMAT编写了该自定义函数,以便您可以反复使用它。 选项2:也许在PHP中重新格式化日期以匹配数据库中的日期格式,有点像

  

$ after7Days->格式(' Y-M-d&#39);

答案 2 :(得分:0)

DATE_FORMAT不是字符串函数,它的date_function:

  

config.yml

doctrine:
     orm:
         dql:
             datetime_functions:
                 date_format: DoctrineExtensions\Query\Mysql\DateFormat

答案 3 :(得分:0)

我不确定,但这对我来说是正确的:

doctrine:
    orm:
        entity_managers:
            default:
                ...
                dql:
                    datetime_functions:
                        DATE_FORMAT: DoctrineExtensions\Query\Mysql\DateFormat

答案 4 :(得分:0)

Symfony 5答案

运行

composer require beberlei/doctrineextensions

添加

config / packages / doctrine.yaml

doctrine:
    orm:
        dql:
            datetime_functions:
                DATE_FORMAT: DoctrineExtensions\Query\Mysql\DateFormat

其他 datetime 函数也是如此:

doctrine:
    orm:
        dql:
            datetime_functions:
                DATE_FORMAT: DoctrineExtensions\Query\Mysql\DateFormat
                DAY: DoctrineExtensions\Query\Mysql\Day
                MONTH: DoctrineExtensions\Query\Mysql\Month
                YEAR: DoctrineExtensions\Query\Mysql\Year