QueryDSL 中的多列 WHERE-IN 子句
Multicolumn WHERE-IN clause in QueryDSL
我是 QueryDSL 的新手,能够 assemble 在 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 中完成?
提前致谢!
我不确定在子查询中选择多个字段,但是对于一个字段,它的工作方式如下,使用 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>
。
我遇到了同样的问题,我花了一天时间才找到解决方案。您可以使用 Expressions.list() 为 in 子句指定多个列。
因此,您应该在 where() 子句中包含以下内容:
Expressions.list(t1.col1, t1.col2).in(
JPAExpressions.select(t2.col1, t2.col2)
.from(t2)
.where(...)
)
希望对大家有所帮助。
我是 QueryDSL 的新手,能够 assemble 在 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 中完成?
提前致谢!
我不确定在子查询中选择多个字段,但是对于一个字段,它的工作方式如下,使用 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>
。
我遇到了同样的问题,我花了一天时间才找到解决方案。您可以使用 Expressions.list() 为 in 子句指定多个列。
因此,您应该在 where() 子句中包含以下内容:
Expressions.list(t1.col1, t1.col2).in(
JPAExpressions.select(t2.col1, t2.col2)
.from(t2)
.where(...)
)
希望对大家有所帮助。