JPA|JPA CriteriaBuilder子查询方式
目录
- JPA CriteriaBuilder子查询
- Jpa在CriteriaBuilder中添加where条件NotIn子查询
JPA CriteriaBuilder子查询 给自己做个备忘
/** 检索关键字 */if (keyWord != null && !keyWord.trim().equals("")){// 创建子查询对象 Subquery subquery = criteriaQuery.subquery(Store.class); Root root2 = subquery.from(Store.class); subquery.select(root2. get("id")); subquery.where(criteriaBuilder.like(root2. get("name"), "%" + keyWord + "%")); // 给读者稍微解释一下,也给自己留个记忆// 这里的意图是将关键做两个模糊检索,一个是在本表中检索title字段// 就是criteriaBuilder.like(root. get("title"), "%" + keyWord + "%")// 二是将字段与子表中的检索出来的id与本表中store字段做匹配// criteriaBuilder.in(root.get("store")).value(subquery))// 至于id怎么检索出来的,用子查询模糊检索出来的,参照上面的子查询 restrictions = criteriaBuilder.and(restrictions,criteriaBuilder.or(criteriaBuilder.like(root. get("title"), "%" + keyWord + "%"),criteriaBuilder.in(root.get("store")).value(subquery))); }
Jpa在CriteriaBuilder中添加where条件NotIn子查询
final CriteriaBuilder cb = entityManager.getCriteriaBuilder(); final CriteriaQuery cq = cb.createQuery(Person.class); final Root root = cq.from(Person.class); cq.select(root); final Subquerysubquery = cq.subquery(Integer.class); final Root validityIDSQ = subquery.from(Person.class); subquery.select(cb.max(validityIDSQ.get(Person_.validityID))); subquery.groupBy(validityIDSQ.get(Person_.personID)); cq.where(cb.in(root.get(Person_.validityID)).value(subquery)); // 将生成selectperson0_.id as id1_0_,person0_.personID as personID2_0_,person0_.validityID as validity3_0_,person0_.value as value4_0_fromperson person0_whereperson0_.validityID in (selectmax(person1_.validityID)fromperson person1_group byperson1_.personID)
自身所需NotIn语法,所以是
Subquery manageUserSubquery = query.subquery(String.class); RootrelationUserManagePlateDomainRoot = manageUserSubquery.from(RelationUserManagePlateDomain.class); Join relationUserManagePlateDomainUserDomainJoin = relationUserManagePlateDomainRoot.join(RelationUserManagePlateDomain_.user, JoinType.INNER); Subquery subquery = manageUserSubquery.select(relationUserManagePlateDomainUserDomainJoin.get(UserDomain_.id)); Predicate predicate1 = criteriaBuilder.and(criteriaBuilder.not(criteriaBuilder.in(root.get(UserDomain_.id)).value(manageUserSubquery))); predicate.getExpressions().add(predicate1);
【JPA|JPA CriteriaBuilder子查询方式】以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
推荐阅读
- 2018年11月19日|2018年11月19日 星期一 亲子日记第144篇
- 遇到一哭二闹三打滚的孩子,怎么办┃山伯教育
- 这辈子我们都不要再联系了
- 2019年12月24日
- Ⅴ爱阅读,亲子互动——打卡第178天
- 眼观耳听美食的日子
- 子龙老师语录
- 成交的种子咖啡冥想
- 2018年9月5日,星期三,天气晴
- 生活随笔|好天气下的意外之喜