我是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中完成?
提前致谢!
最佳答案 我遇到了同样的问题,我花了一天的时间才找到解决方案.您可以使用Expressions.list()为in子句指定多个列.
所以这是你在where()子句中应该有的东西:
Expressions.list(t1.col1, t1.col2).in(
JPAExpressions.select(t2.col1, t2.col2)
.from(t2)
.where(...)
)
希望它可以帮助某人.