gpt4 book ai didi

java - CriteriaBuilder 使用自定义条件连接两个表

转载 作者:行者123 更新时间:2023-11-30 08:03:12 24 4
gpt4 key购买 nike

我想写这个SQL查询

SELECT *  
FROM A
LEFT OUTER JOIN B
ON A.IDRESOURCE=B.IDRESOURCE AND B.IDLANGUAGE=22;

使用 JPA Criteria Builder。我简单地编写了连接的第一部分:

CriteriaQuery<A> searchQuery = criteriaBuilder.createQuery(A.class);
Root<A> aRoot = searchQuery.from(A.class);
Join<A, B> bJoin= aRoot.join("mappedB", JoinType.LEFT);

但我不知道如何实现条件 B.IDLANGUAGE=22。

有什么方法可以在 Criteria Builder 中实现这一点?

最佳答案

使用JPA 2.1 ONJOIN部分指定,与WHERE相同

CriteriaQuery<A> searchQuery = criteriaBuilder.createQuery(A.class);
Root<A> aRoot = searchQuery.from(A.class);
Join<A, B> bJoin= aRoot.join("mappedB", JoinType.LEFT);
bJoin.on(criteriaBuilder.equal(bJoin.get("idLanguage"), 22));

关于java - CriteriaBuilder 使用自定义条件连接两个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36406390/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com