【问题标题】:Multicolumn WHERE-IN clause in QueryDSLQueryDSL 中的多列 WHERE-IN 子句
【发布时间】:2016-06-14 19:26:47
【问题描述】:

我是 QueryDSL 的新手,希望能够在 WHERE-IN 子句中组装一个包含多列的查询,例如以下查询:

selec T1.COL1, T1.COL2, .... T1.COL10 
from T1
where (T1.COL1, T1.COL2) IN (select T2.COL1, T2.COL2 from T2 WHERE T2.COL3='a' AND T2.COL4='b')

我把主要查询的部分记下来了:

List<Tuple> result = queryFactory.select(t1.col,...,t1.col10)
.from(t1)
.where(???) // This is the part I'm missing
.fetch();

但我不知道如何实现 where 子句。这在 QueryDSL 中如何实现?

提前致谢!

【问题讨论】:

  • 使用连接,如here 所述。
  • @ursa:连接不一定是 IN 条件的替代品

标签: querydsl


【解决方案1】:

我遇到了同样的问题,我花了一天时间才找到解决方案。您可以使用 Expressions.list() 为 in 子句指定多个列。

因此,您应该在 where() 子句中包含以下内容:

Expressions.list(t1.col1, t1.col2).in(
    JPAExpressions.select(t2.col1, t2.col2)
                      .from(t2)
                      .where(...)
)

希望对某人有所帮助。

【讨论】:

  • 我不再从事 QueryDSL 项目,因此无法在合理的时间投入内测试此答案。我接受是因为我相信这是这样做的方式。谢谢你,蒂米!
【解决方案2】:

我不确定在子查询中选择多个字段,但对于一个字段,它的工作原理如下,使用JPASubQuery

ListSubQuery<Integer> subQuery = new JPASubQuery()
    .from(t2)
    .where(t2.col3.eq('a')).and(t2.col4.eq('b'))
    .list(t2.col1);

然后在您的查询中使用它:

List<Tuple> result = queryFactory.select(t1.col,...,t1.col10)
    .from(t1)
    .where(t1.col1.in(subQuery))
    .fetch();

使用ListSubQuery&lt;Tuple&gt; 可能有多个字段。

【讨论】:

  • 但问题是在IN 条件中使用多于一列。
猜你喜欢
  • 2019-06-24
  • 1970-01-01
  • 2013-05-31
  • 2018-07-01
  • 1970-01-01
  • 2018-07-19
  • 2011-10-18
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多