首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >QueryDSL中的多clause子句

QueryDSL中的多clause子句
EN

Stack Overflow用户
提问于 2016-06-14 19:26:47
回答 2查看 5.8K关注 0票数 6

我是QueryDSL新手,我可以在WHERE子句中使用多个列组装一个查询,如下所示:

代码语言:javascript
复制
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')

下面是主要查询的部分:

代码语言:javascript
复制
List<Tuple> result = queryFactory.select(t1.col,...,t1.col10)
.from(t1)
.where(???) // This is the part I'm missing
.fetch();

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

提前感谢!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-06-10 15:21:54

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

下面是where()子句中应该包含的内容:

代码语言:javascript
复制
Expressions.list(t1.col1, t1.col2).in(
    JPAExpressions.select(t2.col1, t2.col2)
                      .from(t2)
                      .where(...)
)

希望它能帮到别人。

票数 6
EN

Stack Overflow用户

发布于 2016-06-24 13:01:54

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

代码语言:javascript
复制
ListSubQuery<Integer> subQuery = new JPASubQuery()
    .from(t2)
    .where(t2.col3.eq('a')).and(t2.col4.eq('b'))
    .list(t2.col1);

然后在查询中使用它:

代码语言:javascript
复制
List<Tuple> result = queryFactory.select(t1.col,...,t1.col10)
    .from(t1)
    .where(t1.col1.in(subQuery))
    .fetch();

可能多个字段通过使用ListSubQuery<Tuple>工作。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37820514

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档