JPA实现多条件分页查询

 更新时间:2024年07月17日 09:24:20   作者:小炎说java  
这篇文章主要介绍了JPA实现多条件分页查询方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

JPA多条件分页查询

  • jpa单表自定义查询条件
  • 同时支持分页查询

分页查询准备工作

  • 1:实体类注入pageNum与pageSIze,建议pageNum为1,pageSize为100000,这样可以保证没有分页查询时,可以查询全部的数据
  • 2:默认定义好,同时需要添加@Transient,非数据库字段
public class 实体类 {

    @Transient
    private int pageNum=1;

    @Transient
    private int pageSize=10000;
|

使用分页查询

  • 1:PageRequest.of():生成带有开始页,尺寸,排序方式,排序字段的Pageable
  • 2:这里因为一开始定义的pageNum为1,需减1
  • 3:这么使用,是方便前端的设值,以及ui分页查询的
  • 4:指定排序字段,必须要带_
Pageable pageable=PageRequest.of(recruit.getPageNum()-1,recruit.getPageSize(),
                Sort.Direction.DESC,"createTime");

recruitRepository.findAll(specification,pageable);

自定义查询条件

  • 1:首先需要判定传入的值是否存在,且不为空
  • 2:时间类型为between and,需保证两个时间都不为空
  • 3:JPA支持in equal like between and
  • 4:reposotory层需继承JpaRepository,JpaSpecificationExecutor
Specification<PersonnelRecruit> specification = (root, criteriaQuery, criteriaBuilder) -> {
            List<Predicate> predicates = new ArrayList<>();
            if (StringUtils.isNotBlank(recruit.getDept())) {
                predicates.add(criteriaBuilder.equal(root.get("dept"),recruit.getDept()));
            }

            if (StringUtils.isNotBlank(recruit.getName())) {
                predicates.add(criteriaBuilder.like(root.get("name"),"%"+recruit.getName()+"%"));
            }

            if (ObjectUtils.isNotNull(recruit.getCreateTime()) && ObjectUtils.isNotNull(recruit.getCreateEndTime())) {
                predicates.add(criteriaBuilder.between(root.get("createTime"),recruit.getCreateTime(),recruit.getCreateEndTime()));
            }
            Predicate[] p = predicates.toArray(new Predicate[0]);
            return criteriaBuilder.and(p);
        };

 Pageable pageable=PageRequest.of(recruit.getPageNum()-1,recruit.getPageSize(),
                Sort.Direction.DESC,"createTime");
 return recruitRepository.findAll(specification,pageable);

JPA多条件动态分页查询

之前发过用JPA接口动态查询,单独写了个EXT扩展类拼接sql语句,随着我入行时间的增加,我变强了,所以我在这里记录分享一个更为简单的动态分页查询方法。

废话少说,上代码了:

    public Page<QualityTaskDto> findQualityTaskByPage(Integer pageNum, Integer pageSize, String tasktype, String jobname, String satellite) {
        Sort sort = Sort.by(Sort.Direction.ASC, "creatTime");
        Pageable pageable = new PageRequest(pageNum,pageSize,sort);
        Specification<DbDmsQualityTaskInfoDTO> specification = (root, query, cb) ->{
            List<Predicate> predicates = new LinkedList<>();
            if(StringUtils.isNotBlank(tasktype)){
                predicates.add(cb.equal(root.get("tasktype"),tasktype));
            }
            if(StringUtils.isNotBlank(jobname)){
                predicates.add(cb.like(root.get("jobname"),"%"+jobname+"%"));
            }//模糊查询
            if(StringUtils.isNotBlank(satellite)){
                predicates.add(cb.equal(root.get("satellite"),satellite));
            }
            return cb.and(predicates.toArray(new Predicate[predicates.size()]));
        };
        Page<DbDmsQualityTaskInfoDTO> all = qualityTaskInfoDAO.findAll(specification,pageable);
        List<QualityTaskDto> qualityTaskDtos = qualityTaskDto.db2Dto(all.getContent());
        return new PageImpl<>(qualityTaskDtos,pageable,all.getTotalElements());
    }

接受参数看具体情况 ,用了拉姆达表达式,这样子然后sql直接可以用jpa内部接口就好了,简单暴力管用,无敌了!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java实现从PLC读取数据的常见主流且可行方案

    Java实现从PLC读取数据的常见主流且可行方案

    要从PLC读取数据,Java本身并不直接支持PLC的通信协议,所以你需要借助一些中间件或库来实现,以下是几种主流且可行的方案,大家可以根据自己的需要进行选择
    2026-03-03
  • SpringBoot使用Prometheus实现监控

    SpringBoot使用Prometheus实现监控

    在当今的软件开发世界中,监控是至关重要的一部分,本文主要介绍了如何在Spring Boot应用程序中使用Prometheus进行监控,以帮助大家更好地理解和管理您的应用程序,有需要的可以参考下
    2023-10-10
  • Java中Stream流Map分组方式详细汇总

    Java中Stream流Map分组方式详细汇总

    Stream将要处理的元素集合看作一种流,在流的过程中借助Stream API对流中的元素进行操作,比如筛选、排序、聚合等,下面这篇文章主要给大家介绍了关于Java中Stream流Map分组方式的相关资料,需要的朋友可以参考下
    2024-01-01
  • Java Socket使用加密协议进行传输对象的方法

    Java Socket使用加密协议进行传输对象的方法

    这篇文章主要介绍了Java Socket使用加密协议进行传输对象的方法,结合实例形式分析了java socket加密协议相关接口与类的调用方法,以及服务器、客户端实现技巧,需要的朋友可以参考下
    2017-06-06
  • Java压缩文件操作详解

    Java压缩文件操作详解

    这篇文章主要为大家详细介绍了如何利用Java语言进行压缩文件操作,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2022-08-08
  • Jvm sandbox mock机制的实践过程

    Jvm sandbox mock机制的实践过程

    这篇文章主要介绍了Jvm sandbox mock机制的实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • 浅谈Java中IO和NIO的本质和区别

    浅谈Java中IO和NIO的本质和区别

    IO的全称是input output,是java程序跟外部世界交流的桥梁,IO指的是java.io包中的所有类,他们是从java1.0开始就存在的。NIO叫做new IO,是在java1.4中引入的新一代IO。IO的本质是什么呢?它和NIO有什么区别呢?我们该怎么学习IO和NIO呢?看完这篇文章一切都有答案。
    2021-06-06
  • Java中四种访问权限资料整理

    Java中四种访问权限资料整理

    这篇文章主要介绍了 Java中四种访问权限总结的相关资料,需要的朋友可以参考下
    2017-05-05
  • SpringBoot集成MaxCompute的示例代码

    SpringBoot集成MaxCompute的示例代码

    这篇文章主要介绍了SpringBoot集成MaxCompute的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • Java中的static静态变量、静态方法超详细讲解

    Java中的static静态变量、静态方法超详细讲解

    Java中的static关键字用于表示静态变量和静态方法,静态变量是类的成员变量,它们属于类本身,而不是类的实例,这篇文章主要给大家介绍了关于Java中static静态变量、静态方法详细讲解的相关资料,需要的朋友可以参考下
    2024-06-06

最新评论