it-roy-ru.com

Построитель запросов доктрины DATE_FORMAT не работает

У меня возникли проблемы с DATE_FORMAT внутри createQueryBuilder

Мой код:

$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/

7
Pedro Luz

DATE_FORMAT вместе с набором функций Mysql не доступны напрямую в Doctrine.

Чтобы использовать их, вы можете либо создать свое собственное, либо добавить расширение, например beberlei/DoctrineExtensions , а затем добавить соответствующую функцию в конфигурацию пакета доктрины, например:

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

DATE_FORMAT не является признанной доктриной функцией. Та ссылка, которую вы вставили, является пользовательским кодом, который автор написал для него, чтобы получить date_formate. Вы можете написать собственные функции в доктрине и зарегистрировать их, аккуратно?

Вот пример того, как это сделать - http://symfony.com/doc/current/cookbook/doctrine/custom_dql_functions.html

Вариант 1. Вы пишете эту пользовательскую функцию для DATE_FORMAT, чтобы вы могли использовать ее снова и снова. Вариант 2. Может быть переформатировать дату в PHP, чтобы она соответствовала формату даты в базе данных, вроде как 

$ After7Days-> Формат ( 'Y-м-д');

1
user534462

Я не уверен, но это верно только для меня:

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

DATE_FORMAT не является строковой функцией, ее date_function:

config.yml

doctrine:
     orm:
         dql:
             datetime_functions:
                 date_format: DoctrineExtensions\Query\Mysql\DateFormat
0
Lauris Kuznecovs