php - 教义查询生成器 DATE_FORMAT 不工作

标签 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/

最佳答案

DATE_FORMAT 以及一堆 Mysql 函数在 Doctrine 中不直接可用。

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

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

关于php - 教义查询生成器 DATE_FORMAT 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26298175/

相关文章:

php - 覆盖 wp-login.php 样式

php - 我的输入不会将信息插入我的数据库/ fatal error

php - 如何检查单选按钮是否包含正确答案?

java - 如何在java中解析缺少年份信息的日期

php - 如何为我的网站实现泰米尔语字体?

php - 使用 Smarty 进行分页(上一个 | 下一个)

列类型更新后 MySQL 表 "crashed"

mysql - 如何将查询结果插入到mysql的表中?

javascript datetime 将零添加到单个数字值

ios - 在iOS上更改日期格式