web-dev-qa-db-ja.com

Doctrine querybuilderDATE_FORMATが機能していません

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/

8
Pedro Luz

DATE_FORMATと一連のMysql関数はDoctrineでは直接利用できません。

それらを使用するには、独自の拡張機能を作成するか、 beberlei/DoctrineExtensions のような拡張機能を追加してから、それぞれの関数をdoctrine bundle config like

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

DATE_FORMATはdoctrine認識された関数ではありません。貼り付けたリンクは、作成者がdate_formateを取得するために作成したカスタムコードです。カスタム関数はdoctrineそしてそれらを登録します、きちんとしたey?

これを行う方法の例を次に示します--- http://symfony.com/doc/current/cookbook/doctrine/custom_dql_functions.html

オプション1:DATE_FORMATのカスタム関数を記述して、何度も使用できるようにします。オプション2:たぶんPHPの日付をデータベースの日付形式と一致するように再フォーマットします。

$ after7Days-> format( 'Y-m-d');

1
user534462

DATE_FORMATは文字列関数ではなく、そのdate_function:

config.yml

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

よくわかりませんが、これは私だけに当てはまります。

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