如何将此转换为Doctrine 2 QueryBuilder格式?

16

我想使用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

我遇到了转换第二个 SELECT 语句的问题。

谢谢您提前帮助。

我想使用 createQueryBuilder 而不是 createQuery 来实现它。

1个回答

38
尝试这个:
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))
      ....;

我测试过并且它可以运行 :)


我想要使用 createQueryBuilder - pmoubed
我修改了查询(详见上文)。 - a.aitboudad
出现了一些问题。我收到了“无效参数号:绑定变量的数量与标记数量不匹配”的错误信息...您能否检查一下这段代码,并让我知道我错在哪里。 https://www.evernote.com/shard/s338/sh/70b0db2c-a1f8-4c82-ac87-8f6b934be18d/4128fff89622337fa80e7f5aa49c26e7 - Roydon D' Souza
2
@RoydonD'Souza 子查询不考虑参数(getDQL),您应该将参数传递给 $qb。 - a.aitboudad
@a.aitboudad 非常感谢。我会这样做的。 - Roydon D' Souza

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接