JPA简单的分页条件查询
1,service层代码:
@Override
public QrCodeRecordPaging getPage(String projectId, Integer pageNumber, Integer pageSize) {
//创建时间排序
Sort sort = new Sort(Sort.Direction.DESC, "createAt");
//不合法给予默认值
if (pageNumber == null || pageSize == null || pageNumber <= 0 || pageSize <= 0) {
pageNumber = 1;
pageSize = Integer.MAX_VALUE;
}
PageRequest pageRequest = new PageRequest(pageNumber - 1, pageSize, sort);
//返回分页信息
Page<QrCodeRecord> all = qrCodeRecordRepository.findAll((root, query, cb) -> {
//断言,添加断言
Predicate p = cb.equal(root.get("projectId").as(String.class), projectId);
return cb.and(p);
}, pageRequest);
return recordAssembler.toPage(all);
}
看一下业务层就好,下面是我们自己公司封装的model,外人不要看了,没意义
2,转换封装成需要的modelPaging
public QrCodeRecordPaging toPage(Page<QrCodeRecord> all) {
QrCodeRecordPaging paging = new QrCodeRecordPaging();
List<QrCodeRecordModel> models = new ArrayList<>();
all.forEach(qrCodeRecord -> models.add(toQrCodeRecordModel(qrCodeRecord)));
paging.setData(new Items<QrCodeRecordModel>().init(models));
paging.setFirst(all.isFirst());
paging.setHasNext(all.hasNext());
paging.setHasPrevious(all.hasPrevious());
paging.setLast(all.isLast());
paging.setPageNumber(all.getNumber() + 1);
paging.setPageSize(all.getSize());
paging.setTotalPage(all.getTotalPages());
paging.setTotalElements(all.getTotalElements());
return paging;
}
3,返回的model
public class QrCodeRecordPaging extends PageModel<QrCodeRecordModel> {
}
JPA简单的分页条件查询的更多相关文章
- Mybatis 的分页条件查询语句编写
刚来到一家新公司, 翻看项目代码, 发现一位同事写的查询逻辑很好, 不用插件, 一个语句完成了分页条件查询. 而我之前一般都是在业务层对参数进行判断, 如果有条件,就调用条件查询的方法, 如果没有条件 ...
- thinkphp分页+条件查询
最近项目上面有一个带条件查询的分页列表,一开始form用的post,点击第二页就没有跳转成功,原因是分页是get请求,post数据链接到其他页面就会被清除. 解决办法: 1.form表单method= ...
- 【Spring Data 系列学习】Spring Data JPA 自定义查询,分页,排序,条件查询
Spring Boot Jpa 默认提供 CURD 的方法等方法,在日常中往往时无法满足我们业务的要求,本章节通过自定义简单查询案例进行讲解. 快速上手 项目中的pom.xml.application ...
- webform:分页组合查询
一个简单的分页组合查询页面 /// <summary> /// 查询方法 /// </summary> /// <param name="tsql"& ...
- javascript:设置URL参数的方法,适合多条件查询
适用场景:多条件查询情况,如下图所示: 通过设置URL参数,再结合数据源控件设置的RUL参数,就能进行简单的多条件查询了. javascript函数: <mce:script type=&quo ...
- spring data jpa实现多条件查询(分页和不分页)
目前的spring data jpa已经帮我们干了CRUD的大部分活了,但如果有些活它干不了(CrudRepository接口中没定义),那么只能由我们自己干了.这里要说的就是在它的框架里,如何实现自 ...
- Spring MVC和Spring Data JPA之按条件查询和分页(kkpaper分页组件)
推荐视频:尚硅谷Spring Data JPA视频教程,一学就会,百度一下就有, 后台代码:在DAO层继承Spring Data JPA的PagingAndSortingRepository接口实现的 ...
- SpringBoot JPA + 分页 + 单元测试SpringBoot JPA条件查询
application.properties 新增数据库链接必须的参数 spring.jpa.properties.hibernate.hbm2ddl.auto=update 表示会自动更新表结构,所 ...
- 【JPA】表达条件查询的关键字
1.通过解析方法名创建查询 框架在进行方法名解析时,会先把方法名多余的前缀截取掉,比如 find.findBy.read.readBy.get.getBy,然后对剩下部分进行解析.并且如果方法的最后一 ...
随机推荐
- How DRI and DRM Work
How DRI and DRM Work Introduction This page is intended as an introduction to what DRI and DRM are, ...
- wxWidgets源码分析(2) - App主循环
目录 APP主循环 MainLoop 消息循环对象的创建 消息循环 消息派发 总结 APP主循环 MainLoop 前面的wxApp的启动代码可以看到,执行完成wxApp::OnInit()函数后,接 ...
- 后端程序员之路 40、Pthreads
POSIX线程(POSIX threads),简称Pthreads,是线程的POSIX标准.线程这个东西在操作系统原理里讲得比较清楚了,再加上对windows那一套进程线程的东西比较清楚,所以这里还是 ...
- pytorch(14)权值初始化
权值的方差过大导致梯度爆炸的原因 方差一致性原则分析Xavier方法与Kaiming初始化方法 饱和激活函数tanh,非饱和激活函数relu pytorch提供的十种初始化方法 梯度消失与爆炸 \[H ...
- Spring Security 整合 微信小程序登录的思路探讨
1. 前言 原本打算把Spring Security中OAuth 2.0的机制讲完后,用小程序登录来实战一下,发现小程序登录流程和Spring Security中OAuth 2.0登录的流程有点不一样 ...
- Java 开发工具
开发工具·Eclipse 常见开发工具介绍 * A:操作系统自带的记事本软件 * B:高级记事本软件 * C:集成开发环境 IDE * (Integrated Development Envi ...
- SQL字符串传参
technicianCode in('${techList.collect { it.technicianCode }.join("','")}')
- 【海思】Hi3516A 运行sample_venc的demo内核奔溃(DDR问题)
作者:李春港 出处:https://www.cnblogs.com/lcgbk/p/14514297.html 目录 一.前言 二.使用memtester对ddr进行压力测试 三.修改uboot的DD ...
- SpringMVC自定义兼容性Handler
写在前面 看到这篇博客时,默认你知道Spring MVC中handler的作用,及前台请求到响应的的流转. 感谢网上其他大佬博客给我的借鉴,博客地址这里忘记了. 自定义Handler 我有时候会考虑是 ...
- Django1和2的区别
一.路由的区别 1.Django1中的url from django.conf.urls import url # 使用url关键字 urlpatterns = [ url('article-(\d+ ...