jhipster(springboot+datatable+jpa)后台分页,总结
最近用datatable做了一个后台分页,但是后台实体原本没写DTO。就碰到的问题做了一下总结
一、datatable使用get方式传数据到后台,这是正常的后台分页,不涉及过滤查询和前端传递的排序字段,后面会细讲
后台使用
@GetMapping("/jobs")
@ResponseBody
public ResponseEntity<List<AuditJob>> getAllTestPages(@ApiParam Pageable pageable) {
log.debug("REST request to get a page of TestPages");
Page<AuditJob> page = auditJobRepository.findAll(pageable);
HttpHeaders headers = PaginationUtil.generatePaginationHttpHeaders(page, "/api/test-pages");
return new ResponseEntity<>(page.getContent(), headers, HttpStatus.OK);
}
二、使用DTO
sql语句:
这里需要注意的是,
1、这里用到了DTO,自己建了一个实体类的DTO,只查询出自己需要的字段,但是字段名必须和Dto的构造参数字段操持一致
2、自定义的查询方法,要加上@Modifing
3、这里使用的对象查询,所以sql语句中要和实体的属性名对应,如果要写原生sql语句,就要写在括号里面加 , nativeQuery = true
4、Dto类要有getter和setter、构造方法
5、自定义的查询方法不能用自带的Pageable参数,如果要分页需要自己写分页语句。使用框架自带的分页查询泛型必须是数据库存在的实体
@Transactional
@Query(value = "select new com.famessoft.oplus.cac.domain.AuditJobDto(id,templateName,createdBy,createdAt,endedAt,auditParams,jobStatus) " +
"from AuditJob order by ?3 ?4 limit ?1,?2")
@Modifying
List<AuditJobDto> findAuditDtoByPage(String start,String end,String orderCol,String order);//这里的end是start+length
这里使用了DTO,要写包名,不然会不认识
注意,泛型那里是返回没有DTO的实体,这样子自己就回映射(注意字段名一定要对应)
这里不是自定义的方法,所以不用写@modifing,这是根据jpa的标准语法来写的
@Query(value = "select new com.famessoft.oplus.cac.domain.AuditJobDto(job.id,job.templateName,job.createdBy,job.createdAt,job.endedAt,job.auditParams,job.jobStatus) " +
"from AuditJob job ")
Page<AuditJob> findAuditJobByPage(Pageable pageable);
带分页的查询和过滤
@PostMapping("/jobs/page")
@ResponseBody
public DataTables getAllTestPages(@RequestParam(value = "start", defaultValue = "0") Integer start,
@RequestParam(value = "length", defaultValue = "10") Integer length,
HttpServletRequest request) {
String search = request.getParameter("search[value]");
//针对一个字段排序的
String orderColumn = request.getParameter("order[0][column]");
String order = request.getParameter("order[0][dir]");
//给出默认排序的字段
String sortCol = null;
Sort sort = null;
//获取排序字段
if (orderColumn != null && orderColumn != "") {
//获取datatable排序列(从0开始)
int orderCol = Integer.valueOf(orderColumn);
sortCol = request.getParameter("columns[" + orderCol + "][data]");
if (order != null) {
if (order.toUpperCase().equals(Sort.Direction.DESC)) {
sort = new Sort(Sort.Direction.DESC, sortCol);
} else if (order.toUpperCase().equals(Sort.Direction.ASC)) {
sort = new Sort(Sort.Direction.ASC, sortCol);
}
}
}
DataTables dataTables = new DataTables();
Pageable pageable = new PageRequest(start / length, length, sort);
Page<AuditJob> page = auditJobRepository.findAuditJobByPage(pageable);
if (search == null || search.equals("")) {
dataTables.setData(page.getContent());
dataTables.setRecordsTotal(page.getTotalElements());
dataTables.setRecordsFiltered(page.getTotalElements());
return dataTables;
} else {
//过滤查询
search = "%" + search + "%";
List<AuditJobDto> list = auditJobRepository.findAuditDtoLikeByPage(search);
Page<AuditJob> pageBySearch = auditJobRepository.findAuditJobLikeByPage(search,pageable);
dataTables.setData(pageBySearch.getContent());
dataTables.setRecordsTotal(page.getTotalElements());//这是数据总的条数
dataTables.setRecordsFiltered(pageBySearch.getTotalElements());//过滤查询之后的总数
return dataTables;
}
}
上面那样写其实有点傻,因为碰到了很多问题,因为datatable会吧对象的每个值拆分成每个键值对来传(现在不能回显了),不过类似于
obj={a:1,b:2}传到后台不是obj=>{a:1,b:2}
变成了obj[a]=1
obj[b]=2
这样的值,而且如果使用get方式传递的话中括号还会被转义,根本取不到值,因为key被转义了,所以我换成了post方式传递,取值的方法很笨,但是我还没查到
java针对datatable标准的接收方法,好的一点是,datatable传值的方式是不会变的,所以这样取datatable的值也不会出错,只是代码看起来不是很舒服而已
sql查询语句
这里写了对多字段的模糊查询,所以写了contat函数,但是这个函数针对模糊查询字段等于null的话,这条数据就不会被查询出来,所以需要用ifnull,
还有个小问题,写了IFNULL函数之后,编译会报错,但是不用管它,这个会正常运行的
https://blog.csdn.net/yaoyao9565/article/details/51305854
@Query(value = "select new com.famessoft.oplus.cac.domain.AuditJobDto(job.id,job.templateName,job.createdBy,job.createdAt,job.endedAt,job.auditParams,job.jobStatus) " +
"from AuditJob job where concat(IFNULL(templateName,'') ,IFNULL(createdBy,''),IFNULL(createdAt,''),IFNULL(endedAt,''),IFNULL(auditParams,''),IFNULL(jobStatus,'')) like ?1 ")
Page<AuditJob> findAuditJobLikeByPage(String search,Pageable pageable);
注:
我如果重写findAll()或者自定义查询然后只取部分的属性,会导致我调用findOne的时候也会只取那些属性。但是后面好像又好了,有点莫名其妙
jhipster(springboot+datatable+jpa)后台分页,总结的更多相关文章
- Springboot+Atomikos+Jpa+Mysql实现JTA分布式事务
1 前言 之前整理了一个spring+jotm实现的分布式事务实现,但是听说spring3.X后不再支持jotm了,jotm也有好几年没更新了,所以今天整理springboot+Atomikos+jp ...
- 【极简版】SpringBoot+SpringData JPA 管理系统
前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 在上一篇中已经讲解了如何从零搭建一个SpringBo ...
- 带你搭一个SpringBoot+SpringData JPA的环境
前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 不知道大家对SpringBoot和Spring Da ...
- 二、springboot使用jpa
花了几天时间,好好看了看springboot的jpa部分,总结了常用的形式. 1.通过STS工具添加jpa的依赖项 要连mysql,测试的时候需要web,顺便添加了lombok不写set和get方法了 ...
- Springboot+MyBatis+JPA集成
1.前言 Springboot最近可谓是非常的火,本人也在项目中尝到了甜头.之前一直使用Springboot+JPA,用了一段时间发现JPA不是太灵活,也有可能是我不精通JPA,总之为了多学学Sp ...
- 第11章—使用对象关系映射持久化数据—SpringBoot+SpringData+Jpa进行查询修改数据库
SpringBoot+SpringData+Jpa进行查询修改数据库 JPA由EJB 3.0软件专家组开发,作为JSR-220实现的一部分.但它又不限于EJB 3.0,你可以在Web应用.甚至桌面应用 ...
- 集成Springboot+MyBatis+JPA
1.前言 Springboot最近可谓是非常的火,本人也在项目中尝到了甜头.之前一直使用Springboot+JPA,用了一段时间发现JPA不是太灵活,也有可能是我不精通JPA,总之为了多学学Spri ...
- SpringBoot Data JPA 关联表查询的方法
SpringBoot Data JPA实现 一对多.多对一关联表查询 开发环境 IDEA 2017.1 Java1.8 SpringBoot 2.0 MySQL 5.X 功能需求 通过关联关系查询商店 ...
- 用SpringBoot+MySql+JPA实现对数据库的增删改查和分页
使用SpringBoot+Mysql+JPA实现对数据库的增删改查和分页 JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述 ...
随机推荐
- thunder 更改迅雷默认播放器
更改迅雷的边下边播默认播放器 CreateTime--2017年10月31日08:33:57 Author:Marydon 1.找到迅雷的安装目录,如:D:\SoftWares\PortableE ...
- eclipse中查看某个方法(函数)被谁调用
用了好久一直不知道eclipse中怎样实现vs中查找全部引用的功能,今天最终发现了哈哈 选中要查找的方法名,右键->References->Workspace 能够定位到详细的调用位置,快 ...
- STM32出现HardFault故障的解决方法
https://wenku.baidu.com/view/a4a7499afad6195f312ba6d2.html https://wenku.baidu.com/view/085b6fbe5022 ...
- java同一个实体的复制
import org.springframework.beans.BeanUtils; //将mon的值复制给monitorCommission;monitorCommission是实体Monitor ...
- 用于检测进程的shell脚本代码小结
本文介绍一段shell脚本,它可以检测某进程或某服务是否正在运行,然后以邮件通知.有需要的朋友参考下 一个简单的shell脚本,用来找出关键的服务是否正在运行,适用于Linux操作系统或Unix操作系 ...
- 异步FIFO的FPGA实现
本文大部分内容来自Clifford E. Cummings的<Simulation and Synthesis Techniques for Asynchronous FIFO Design&g ...
- 通达OA 几次通过OA进行的足球抢票活动确实对OA系统提出了非常大挑战
今年集团赞助了中超的足球比赛,有比赛的时候会提前发一些球票.怎么发.发给谁这就是一个问题.后来确定通过OA来抢票. 通过在OA上发表帖子.通过信息提醒.大家看到信息提示后在帖子后面回复,依据回复先后确 ...
- 50篇经典珍藏 | Docker、Mesos、微服务、云原生技术干货
概念篇 全方位探(tian)索(keng)Mesos各种存储处理方式 老肖有话说@Mesos User Group第四次约会 技术实践 | Mesos 全方位“烹饪”指南 回顾 JAVA 发展轨迹,看 ...
- linux命令汇总1
允许非root用户使用“sudo” root身份登录系统,执行“visudo”,根据示例添加新的一个规则(记住输入的密码是当前用户密码,而不是root密码)#不需要密码执行sudo命令hadoop ...
- CentOS 7.0 关闭firewalld防火墙指令 及更换Iptables防火墙
CentOS 7.0 关闭firewalld防火墙指令 及更换Iptables防火墙 时间:2014-10-13 19:03:48 作者:哎丫丫 来源:哎丫丫数码网 查看:11761 评论:2 ...