15

Doctrineでネストされたクエリを書きたいです。サンプルSQLは次のようになります。

SELECT * FROM layer WHERE layer.id NOT IN 
               (SELECT task_id FROM users_tasks WHERE user_id = 1) 
AND parent_id IS NOT NULL AND leaf IS TRUE

SECOND SELECTステートメントの変換に問題があります。

前もって感謝します。

createQueryBuildernotで作りたいcreateQueryです。

4

1 に答える 1

37

これを試して :

1) サブクエリを作成する

$subquery = $this->_em->createQueryBuilder()
    ->select('t.id')
    ->from('yourBundle:Task', 't')
    ->innerjoin('t.user','u')
    ->where('u.id = 1')
    ->getDQL();

2)クエリを作成した後

$query = $this->_em->createQueryBuilder();
$query->select('l')
      ->from('yourBundle:Layer', 'l')
      ->where($query->expr()->notIn('l.id', $subquery))
      ....;

私はそれをテストし、それは動作します:)

于 2012-05-26T03:28:05.890 に答える