jpa自定义条件分页查询
主要依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
这里以我最近自己瞎折腾的项目部分代码为例子(仅展示主要部分):
实体类名称(Confusion)
需要注意的是
类上+ @Entity
主键字段+ @Id
package cn.zytao.taosir.disabuse.dao; import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor; import cn.zytao.taosir.common.model.disabuse.Confusion; public interface ConfusionRepository extends JpaRepository<Confusion,String>, JpaSpecificationExecutor<Confusion>{
}
JpaRpository这里就不多讲了,需要注意的是,同时继承JpaSpecificationExecutor
我们发现,继承该类后,可以使用相关的API
T findOne(Specification<T> spec);
List<T> findAll(Specification<T> spec);
Page<T> findAll(Specification<T> spec, Pageable pageable);
List<T> findAll(Specification<T> spec, Sort sort);
long count(Specification<T> spec);

注意Specification类

通过源码可以发现这个方法,关键就是重写它了
在Service层中
@SuppressWarnings({ "deprecation", "serial" })
@Override
public Page<Confusion> findByPageAndParams(Confusion params, int pageNumber, int pageSize) {
Pageable pageable = new PageRequest(pageNumber, pageSize);
Specification<Confusion> confusion=new Specification<Confusion>() {
@Override
public Predicate toPredicate(Root<Confusion> root, CriteriaQuery<?> query,
CriteriaBuilder criteriaBuilder) {
Path<String> theme = root.get("theme");
return criteriaBuilder.like(theme, "%"+params.getTheme()+"%");
}
};
return confusionRepository.findAll(confusion, pageable);
}
如果使用的springboot是2.0X以上的版本,new PageRequest的构造方法已经过时,推荐使用
Pageable pageable = PageRequest.of(pageNumber, pageSize);
以上仅做参考,CriteribBuilder用于构造自定义的查询条件(即条件构造器)

通过相关的方法,我们可以用集合来处理多条件的查询,例子
@Override
public JSONObject list(Integer page, Integer size, String remark,Integer method,Integer status) {
Pageable pageable = PageRequest.of(page-1, size);
Specification<Authority> authorityQuery=new Specification<Authority>() {
@Override
public Predicate toPredicate(Root<Authority> root, CriteriaQuery<?> query, CriteriaBuilder criteriaBuilder) {
List<Predicate> predicates=new ArrayList<>();
if(remark!=null)
predicates.add(criteriaBuilder.like(root.get("remark"), "%"+remark+"%"));
if(method!=null)
predicates.add(criteriaBuilder.equal(root.get("method"), method));
if(status!=null)
predicates.add(criteriaBuilder.equal(root.get("status"), status));
return criteriaBuilder.and(predicates.toArray(new Predicate[predicates.size()]));
}
};
Page<Authority> pageAuthority = authorityMapper.findAll(authorityQuery, pageable);
return ActionHelper.responseOk(pageAuthority.getContent());
}
多条件的例子
控制层
public JSONObject findByParamAndPage(@RequestBody Confusion confusion, int pageNumber, int pageSize) {
Page<Confusion> result = confusionService.findByPageAndParams(confusion, pageNumber, pageSize);
JSONObject data=new JSONObject();
data.put("content", result.getContent());
data.put("totalNums", result.getTotalElements());
data.put("totalPages",result.getTotalPages());
return ActionHelper.responseOk(data);
}
因为这里我的项目使用的是分布式的一个实现方式,所以这里不提供@RequestMapping,自行编写
下面看看在swagger2下的效果。




jpa自定义条件分页查询的更多相关文章
- ASPNETCOREAPI 跨域处理 SQL 语句拼接 多条件分页查询 ASPNET CORE 核心 通过依赖注入(注入服务)
ASPNETCOREAPI 跨域处理 AspNetCoreApi 跨域处理 如果咱们有处理过MV5 跨域问题这个问题也不大. (1)为什么会出现跨域问题: 浏览器安全限制了前端脚本跨站点的访问资源, ...
- asp.net mvc多条件+分页查询解决方案
开发环境vs2010 css:bootstrap js:jquery bootstrap paginator 原先只是想做个mvc的分页,但是一般的数据展现都需要检索条件,而且是多个条件,所以就变成了 ...
- 【java】spring-data-jpa 集成hibernate实现多条件分页查询
初次接触spring-data-jpa,实现多条件分页查询. 基础环境 Spring Boot+spring-data-jpa+hibernate+mysql 1.接口 要继承这个接口,这个接口提供了 ...
- thinkphp 带条件分页查询
thinkphp 带条件分页查询:form表单传值时候,method='get'. 用 get 传值
- 项目一:第四天 1、快递员的条件分页查询-noSession,条件查询 2、快递员删除(逻辑删除) 3、基于Apache POI实现批量导入区域数据 a)Jquery OCUpload上传文件插件使用 b)Apache POI读取excel文件数据
1. 快递员的条件分页查询-noSession,条件查询 2. 快递员删除(逻辑删除) 3. 基于Apache POI实现批量导入区域数据 a) Jquery OCUpload上传文件插件使用 b) ...
- JPA实现复杂条件分页查询
相信熟悉Hibernate的人对于ORM给编程带来的便利于快捷一定不陌生,相对于MyBatis等需要编写复杂的SQL语句,ORM映射为我们带来的便利显而易见.但是,在获得便利的同时,失去的便是灵活性, ...
- spring boot jpa 多条件组合查询带分页的案例
spring data jpa 是一个封装了hebernate的dao框架,用于单表操作特别的方便,当然也支持多表,只不过要写sql.对于单表操作,jpake可以通过各种api进行搞定,下面是一个对一 ...
- JPA分页查询与条件分页查询
情有独钟的JPA 平时在写一些小项目时,比较喜欢引用 Spring Data Jpa,其实还是图他写代码快~在日常的开发工作中,分页列表查询基本是随处可见,下面一起看一下如何使用 jpa 进行多条件查 ...
- mongodb多条件分页查询的三种方法(转)
一.使用limit和skip进行分页查询 public List<User> pageList(int pageNum ,int pageSize){ List<User> u ...
随机推荐
- Python hangman小游戏
hangman # words.py 使用pickle永久性存储数据 import pickle filename = 'words.pk' data = ['cat', 'dog', 'perro' ...
- Windows常用软件
目录 Uninstall Tool FACapture Unlocker Uninstall Tool Uninstall Tool 这是一款可以彻底删除应用的软件,能连通注册表内容一起删除. FAC ...
- 《你又怎么了我错了行了吧》【Alpha】Scrum meeting 5
第五天 日期:2019/6/18 前言: 第5次会议在女生宿舍召开 冲刺第5天,对所有工作做了总结.继续完善编码工作. 1.1 今日完成任务情况以及明天任务安排 姓名 当前阶段任务 下一阶段任务 刘 ...
- CF909A Generate Login
CF909A Generate Login 题意翻译 给定两个用空格分隔的字符串,分别取两字符串的任意非空前缀,将两前缀合并为一个新的字符串,求可行字典序最小的字符串. 题目描述 The prefer ...
- [SharePoint][SharePoint2013循序渐进]SPS2013简介
本章概要: 1.啥是SPS2013 2.SharePoint如何作用于团队协作和信息共享 3.SP2013有哪些用户权限 4.什么是SharePoint2013 online 5.SP在内部署和在线订 ...
- arp与免费arp的差别,arp老化
免费arp:应用场景: case1:PC通过DHCP申请地址.在获取到IP地址后,会发送免费ARP,目的用于探測同一网段时候存在同样的IP地址终端,防止IP冲突. case2:PC的MAC地址发生变化 ...
- 在linux環境下安裝jprofiler_linux_8_0_2.sh
1.安装jprofiler_linux_8_0_2.sh chmod+x jprofiler_linux_8_0_2.sh ./jprofiler_linux_8_0_2.sh –c 安装过程略..差 ...
- bzoj3998: [TJOI2015]弦论(SAM+dfs)
3998: [TJOI2015]弦论 题目:传送门 题解: SAM的入门题目(很好的复习了SAM并加强Right集合的使用) 其实对于第K小的字符串直接从root开始一通DFS就好,因为son边是直接 ...
- iis browse的时候,直接通过本地的局域网ip打开页面
http://www.codepal.co.uk/show/make_IIS_work_with_local_IP_addresses_instead_of_localhost 只需要设置一下webs ...
- 对于NAS,IP SAN以及iSCSCI SAN存储的一些认识和理解
一直以来用户对于在选购存储产品上有许多不清楚,市场上有NAS, FC SAN,IP SAN和iSCSCI SAN产品,到底哪种类型的产品更适合支撑企业的应用系统呢? 我们经常可以听到用户讲: “NAS ...