QueryDSL中的多列WHERE-IN子句

时间:2016-06-14 19:26:47

标签: querydsl

我是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中完成?

提前致谢!

2 个答案:

答案 0 :(得分:2)

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

所以,您在 where()子句中应该拥有的内容:

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

希望它有所帮助。

答案 1 :(得分:0)

我不确定在子查询中选择多个字段,但对于一个字段,它使用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<Tuple>也许可以使用多个字段。