querydsl - QueryDSL 中的多列 WHERE-IN 子句

标签 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 中完成?

提前致谢!

最佳答案

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

所以这里是你的 where() 子句中应该有的内容:

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

希望它可以帮助某人。

关于querydsl - QueryDSL 中的多列 WHERE-IN 子句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37820514/

相关文章:

java - 使用 QuerydslPredicateExecutor 进行 Group by 子句

java - 如何使用谓词通过 JpaRepository.findAll 获取不同的对象列表?

java - Querydsl PathBuilder 字符串参数 'variable' 的用途是什么

java - 在 querydsl 中测试可空性后对值进行相等

elasticsearch - 如何基于聚合输出值在Elasticsearch中获取文档?

spring-webflux - ReactiveQuerydslPredicateExecutor 用于 Reactive WebFlux 的分页

mongodb - 在 Spring data mongo query-dsl 中过滤嵌套映射值

java - 在 querydsl 中调用 mysql 嵌套/内部函数

elasticsearch - 如何在Elasticsearch中查找出现的热门词语

java - Querydsl 中的 date_part 或 EXTRACT 函数