Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Doctrine querybuilder DATE_FORMAT not working

I'm having some problems with DATE_FORMAT inside a createQueryBuilder

My code:

$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();

But im getting

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

I've searched some links and find some explain that it should work this way, but for me it looks like im doing something wrong.

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

like image 839
Pedro Luz Avatar asked Oct 10 '14 11:10

Pedro Luz


1 Answers

Symfony 5 answer

Run

composer require beberlei/doctrineextensions

Add in

config/packages/doctrine.yaml

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

The same goes for other datetime functions:

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
like image 195
Erdal G. Avatar answered Sep 20 '22 14:09

Erdal G.