1

これは私のクエリです:

public function getDetails($userid, $orderby, $sort){

$query = $this->_em->createQueryBuilder()
                ->select('u')
                ->from('\Entities\Users', 'u')
                ->where('u.userid= ?1')
                ->orderBy('u.?3', '?3')
                ->setParameter(1, $userid)
                ->setParameter(2, $orderby)
                ->setParameter(3, $sort)
                ->getQuery()
                ->getResult();

}

エラーが発生し続けます: メッセージ: [Semantical Error] line 0, col 83 near '?3 DESC': Error: '?3' is not defined.

その関数のプロパティからクエリへの orderby を取得するにはどうすればよいですか?

4

2 に答える 2

3

DQLクエリの動的ビルドにプレースホルダーを使用することはできません。自分でコーディングする必要があります。

$sortBy = in_array($sortBy, array(...)) ? $sortBy : 'id';
$sortDir = $sortDir == 'ASC' ? 'ASC' : 'DESC';

$this->em->createQueryBuilder()
    ...
    ->orderBy('u.' . $sortBy, $sortDir)
于 2011-07-22T15:44:43.113 に答える
1

パラメーターを QueryBuilder にバインドすることはできず、クエリにのみバインドすることはできません。そのため、行を交換し、最初にビルダーからクエリを取得してから、パラメーターを入力して結果を取得します。

$query = $this->_em->createQueryBuilder()
            ->select('u')
            ->from('\Entities\Users', 'u')
            ->where('u.userid= ?1')
            ->orderBy('u.?3', '?3')
            ->orderBy('u.'.$orderBy, $sort)
            ->getQuery()
            ->setParameter(1, $userid)
            ->getResult();

}

doctrine 2.4 では修正され、パラメーターを QueryBuilder にバインドできます。

更新: フィールド名にプレースホルダーがある瞬間を逃しました。SQL はそのような構造をサポートしていません。

于 2014-07-30T10:25:25.833 に答える