广告
返回顶部
首页 > 资讯 > 后端开发 > Python >jpa EntityManager 复杂查询实例
  • 723
分享到

jpa EntityManager 复杂查询实例

2024-04-02 19:04:59 723人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录jpaEntityManager复杂查询概念1.注入entitymanager2.建立连接,执行查询操作拓展基于EntityManager的使用1、最基础的查询2、springd

jpa EntityManager复杂查询

概念

  • EntityManager:EntityManager是JPA中用于增删改查的接口,它的作用相当于一座桥梁,连接内存中的java对象和数据库的数据存储。可以用getCriteriaBuilder()的方式获取CriteriaBuilder对象。
  • CriteriaBuilder接口:用于构造标准查询、复合条件、表达式、排序等。可以通过createQuery的方式获取CriteriaQuery实例。
  • CriteriaQuery接口:代表一个specific的顶层查询对象,它包含着查询的各个部分,比如:select 、from、where、group by、order by。
  • Root接口:代表Criteria查询的根对象,定义了实体类型,能为将来导航获得想要的结果,它与sql查询中的FROM子句类似

接下来上代码啦!

1. 注入entitymanager


@PersistenceContext
private EntityManager em;

2. 建立连接,执行查询操作


CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<ADTO> q = cb.createQuery(ADTO.class);
Root<A> root = q.from(A.class);

Join<A, B> b = root.join("b", JoinType.LEFT);
Join<A, C> c = root.join("c", JoinType.LEFT);
Join<A, D> d = root.join("d", JoinType.LEFT);
Join<A, E> e = root.join("e",  JoinType.LEFT);
Join<A, F> f = root.join("f", JoinType.LEFT);
q.multiselect(//备注:ADTO要有对应构造函数哦
        root.get("id"),
        root.get("version"),
        root.get("code"),
        root.get("name"),
        root.get("isAlterable"),
        root.get("mustCharge"),
        root.get("isConsignment"),
        root.get("memo"),
        b.get("id"),
        b.get("name"),
        c.get("id"),
        c.get("description"),
        d.get("id"),
        d.get("name"),
        e.get("id"),
        e.get("name"),
        f.get("id"),
        f.get("name"),
        root.get("standardPrice"),
        root.get("upperPrice"),
        root.get("lowerPrice"),
        root.get("isActive")
);//还可以进行where.order by等操作哦
List<ADTO> rs = em.createQuery(q).getResultList();

到此就完成啦!!!

拓展

where条件


List<Predicate> predicates = new ArrayList<>();
CriteriaBuilder.In<String> in = cb.in(root.get("code").as(String.class));
for (String code: codes) {
    in.value(code);
}
predicates.add(in);
if (startDate != null && !"".equals(startDate)) {
    predicateList.add(cb.greaterThan(birthdayPath, startDate));
}
Predicate[] pre = new Predicate[predicates.size()];
q.where(predicates.toArray(pre));

or 条件拼接


public List<Predicate> getOrSearchPredicates(CriteriaBuilder cb, Root<T> root, String keyWords){
        List<Predicate> predicates = new ArrayList<>();
        Predicate predicate = null;
        Predicate predicate1 = null;
        try {
            UUID uuid = UUID.fromString(keywords);
            predicate1 = cb.equal(root.get("id"), uuid);
        }catch (Exception e){
            log.info(e.getMessage());
        }finally {
            Predicate predicate2 = cb.like(root.get("code"), "%"+keywords+"%");
            Predicate predicate3 = cb.like(root.get("name"), "%"+keywords+"%");
            if (predicate1 != null){
                predicate = cb.or(predicate1, cb.or(predicate2,predicate3));
            } else {
                predicate = cb.or(predicate2, predicate3);
            }
        }
        predicates.add(predicate);
        return predicates;
}

JPA 动态更新


CriteriaBuilder cb=entityManager.getCriteriaBuilder();
CriteriaUpdate<T> op=cb.createCriteriaUpdate(clazz);
Root<T> root=op.from(clazz);
op.set(fieldName, value);
op.where(cb.equal(root.get(keyName), delta.get(keyName)));
entityManager.createQuery(op).executeUpdate();

基于EntityManager的使用

1、最基础的查询


CriteriaBuilder cb = entityManager.getCriteriaBuilder();
CriteriaQuery<User> cq = cb.createQuery(User.class);
Root<User> root = cq.from(User.class); //from User
cq.select(root); //select * from User
javax.persistence.criteria.Predicate pre = cb.equal(root.get("id").as(Integer.class),id);//id=1
cq.where(pre);//where id=1
Query query = entityManager.createQuery(cq);//select u from User u where u.id = 1
System.out.println(query.getResultList());

2、spring data jpa的toPredicate方法


public Predicate toPredicate(Root<RoleEntity> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
    List<Predicate> list = new ArrayList<Predicate>();
    list.add(cb.equal(root.get("dr").as(Integer.class), delete));
    if (StringUtils.isNotBlank(searchParam)) {
        list.add(cb.or(cb.like(root.get("roleName").as(String.class), cb.literal("%" + searchParam + "%")), cb.like(root.get("roleCode").as(String.class), cb.literal("%" + searchParam + "%"))));
    }
    // 角色id
    if (roleId != null && !("".equals(roleId.trim()))) {
        list.add(cb.equal(root.get("id").as(String.class), roleId));
    }
    // 管理员角色标识
    if (cateGory != null && category > 0) {
        list.add(cb.equal(root.get("category").as(Integer.class), category));
    }
    //多角色Id
    if (roleids != null && roleids.size() > 0) {
        list.add(root.get("id").as(String.class).in(roleids));
    }
    Predicate[] predicates = new Predicate[list.size()];
    query.where(list.toArray(predicates));
    query.orderBy(cb.asc(root.get("roleType").as(String.class)), cb.asc(root.get("roleProperty").as(String.class)), cb.asc(root.get("roleCode").as(String.class)));
    return query.getRestriction();
}

参考 org.springframework.data.jpa.repository.support.SimpleJpaRepository 的 findAll方法,如下


public List<T> findAll(Specification<T> spec) {
    return getQuery(spec, (Sort) null).getResultList();
}
protected TypedQuery<T> getQuery(Specification<T> spec, Sort sort) {
    CriteriaBuilder builder = em.getCriteriaBuilder();
    CriteriaQuery<T> query = builder.createQuery(getDomainClass());
    Root<T> root = applySpecificationToCriteria(spec, query);
    query.select(root);
    if (sort != null) {
        query.orderBy(toOrders(sort, root, builder));
    }
    return applyRepositoryMethodMetadata(em.createQuery(query));
}
private TypedQuery<T> applyRepositoryMethodMetadata(TypedQuery<T> query) {
    if (metadata == null) {
        return query;
    }
    LockModeType type = metadata.getLockModeType();
    TypedQuery<T> toReturn = type == null ? query : query.setLockMode(type);
    applyQueryHints(toReturn);
    return toReturn;
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: jpa EntityManager 复杂查询实例

本文链接: https://www.lsjlt.com/news/159326.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • jpa EntityManager 复杂查询实例
    目录jpaEntityManager复杂查询概念1.注入entitymanager2.建立连接,执行查询操作拓展基于EntityManager的使用1、最基础的查询2、springd...
    99+
    2022-11-12
  • jpa EntityManager复杂查询怎么实现
    这篇文章主要讲解了“jpa EntityManager复杂查询怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“jpa EntityManager复杂查询怎么实现”吧...
    99+
    2023-06-22
  • Spring Data Jpa复杂查询的示例分析
    小编给大家分享一下Spring Data Jpa复杂查询的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Spring Data Jpa...
    99+
    2023-06-29
  • JPA 通过Specification如何实现复杂查询
    目录JPA 通过Specification实现复杂查询下面就简单介绍一下Specification的使用spring-data-jpa Specification拼接复杂查询JPA ...
    99+
    2022-11-12
  • JPA怎么通过Specification实现复杂查询
    小编给大家分享一下JPA怎么通过Specification实现复杂查询,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!JPA 通过Specification实现复杂查询JPA中继承BaseRepo之后,可以使用最基本的增删改...
    99+
    2023-06-25
  • Spring Data JPA 实例查询
    三、认识“实例查询” 1、概念定义:    上面例子中,是这样创建“实例”的:Example<Customer> ex = Example.of(customer,...
    99+
    2022-10-18
  • Nest复杂查询示例解析
    目录Nest 复杂查询QueryUserDto是查询参数类型UserService如何实现Nest 复杂查询 复杂查询包括分页、模糊查询、多条件筛选、排序等,满足前端对查询的所有诉求...
    99+
    2022-12-08
    Nest 复杂查询 Nest 查询
  • MyBatis复杂Sql查询实现示例介绍
    目录resultMap 结果映射准备数据多对一查询(association)一对多查询(collection)懒加载resultMap 结果映射 resultMap 元素是 MyBa...
    99+
    2022-12-27
    MyBatis Sql查询 MyBatis复杂Sql查询
  • JPA Specification常用查询+排序实例
    目录JPA Specification常用查询+排序1.第一步:继承父类2.第二步JPA Specification复杂查询+排序需求开始了1.dao2.service3.排序前端结...
    99+
    2022-11-12
  • MySQL查询语句之复杂查询的示例分析
    这篇文章主要介绍MySQL查询语句之复杂查询的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有...
    99+
    2022-10-18
  • Spring Data JPA中的动态查询实例
    spring Data JPA大大的简化了我们持久层的开发,但是实际应用中,我们还是需要动态查询的。比如,前端有多个条件,这些条件很多都是可选的,那么后端的SQL,就应该是可以定制的,在使用hibernate的时候,可以通过判断条件来拼接S...
    99+
    2023-05-31
    spring data jpa
  • Mysql 复杂查询丨联表查询
    💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! JOIN(联表查询) 联表查询(Join)是一种在数据库中使用多个表进行关联查询的操...
    99+
    2023-08-16
    mysql 数据库
  • MySQL之复杂查询的实现
    目录1.排序2.分组3.联合查询4.多表连接1.排序 ORDER BY 子句来设定哪个字段哪种方式来进行排序,再返回搜索结果。desc:降序 select * from b...
    99+
    2022-11-13
  • SpringDataJPA之Specification复杂查询实战
    目录SpringDataJPA Specification复杂查询前言实现Specification与Controller业务逻辑ApiReturnUtil.page封装查询效果可能...
    99+
    2022-11-12
  • [MySQL]复杂查询(进阶)
    专栏简介 :MySql数据库从入门到进阶. 题目来源:leetcode,牛客,剑指offer. 创作目标:记录学习MySql学习历程 希望在提升自己的同时,帮助他人,,与大家一起共同进步,互相成长. 学历代表过去,能力代表...
    99+
    2023-09-09
    数据库 sql mysql
  • MyBatis复杂Sql查询如何实现
    这篇文章主要介绍“MyBatis复杂Sql查询如何实现”,在日常操作中,相信很多人在MyBatis复杂Sql查询如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MyBatis复杂Sql查询如何实现”的疑...
    99+
    2023-07-04
  • 使用QueryBuilders、NativeSearchQuery实现复杂查询
    使用QueryBuilders、NativeSearchQuery实现复杂查询 本文继续前面文章《ElasticSearch系列(二)springboot中集成使用ElasticSearch的Demo...
    99+
    2023-09-10
    elasticsearch java 大数据
  • 继承jpa Repository 写自定义方法查询实例
    目录继承jpa Repository写自定义方法查询首先定义实体类项目报错提示信息为是什么原因呢?JpaRepository常用方法增改删查继承jpa Repository写自定义方...
    99+
    2022-11-12
  • Spring Data Jpa 复杂查询方式总结(多表关联及自定义分页)
    目录Spring Data Jpa复杂查询总结1.查找出Id小于3,并且名称带有shanghai的记录2.通过旅店名称分页查询旅店以及城市的所有信息3.HQL通过旅店名称查询旅店以及...
    99+
    2022-11-13
  • mybatis-plus自带QueryWrapper自定义sql实现复杂查询实例详解
    目录常用写法自定义sql补充: 查询条件中使用函数apply补充: 末尾sql追加last补充:排序补充:Mybatis-Plus QueryWrapper +sql自定义...
    99+
    2022-11-13
    mybatis-plus自定义sql mybatis-plus querywrapper mybatis-plus复杂查询
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作