JPA或Hibernate中使用原生SQL实现分页查询、排序
发生背景:前端展示的数据需要来自A表和D表拼接,A表和D表根据A表的主键进行关联,D表的非主键字段关联C表的主键,根据条件筛选出符合的数据,并且根据A表的主键关联B表的主键(多主键)的条件,过滤A表中不符合的数据。因为数据量较大,所以需要进行分页。
环境:DM DatabaseJ(达梦数据库,和Oracle差不多),JPA
使用@Query注解,使用value属性来声明查询SQL,countQuery属性取得当前查询的数量,nativeQuery属性声明为true,表示为支持当前的SQL语句为原生SQL。 ServiceImpl:
Sort sort = new Sort(Sort.Direction.DESC, "slrq");
Pageable pageable = PageRequest.of(pageNum, pageSize, sort);
Repository:
@Query(value = "SELECT aj.ajmc AS ajmc, " +
"aj.ajlb_bm AS ajlbbm, " +
"aj.ajlb_mc AS ajlbmc, " +
"aj.cbdw_bm AS cbdwbm, " +
"aj.cbdw_mc AS cbdwmc, " +
"aj.cbjcg AS cbjcg, " +
"aj.bmsah AS bmsah, " +
"rz.ysdw_dwdm AS ysdwdm, " +
"rz.ysdw_dwmc AS ysdwmc, " +
"rz.ysay_aydm AS ysaydm, " +
"rz.ysay_aymc AS ysaymc " +
"FROM aj_yx_aj aj " +
"INNER JOIN aj_yx_slrz rz ON aj.bmsah = rz.bmsah " +
"INNER JOIN aj_xt_sldy dy ON rz.slbh = dy.slbm " +
"WHERE aj.sfsc = 'N' " +
"AND aj.cbdw_bm = :cbdwbm " +
"AND (aj.ajmc like :gjz OR aj.cbjcg like :gjz) " +
"AND aj.ajzt = '1' " +
"AND (SELECT COUNT(ry.zrrbm) FROM tyyw_gg_zrrsjls ry WHERE ry.bmsah = aj.bmsah " +
"AND ry.zrrlx_dm = '0009000900001' " +
"AND ry.sfsc = 'N') > 1 " +
"AND dy.sllb = '1' " +
"AND rz.sfsc = 'N' " +
"AND dy.sfsc = 'N' ",
countQuery = "SELECT COUNT(*) FROM " +
"(SELECT * FROM aj_yx_aj aj " +
"INNER JOIN aj_yx_slrz rz ON aj.bmsah = rz.bmsah " +
"INNER JOIN aj_xt_sldy dy ON rz.slbh = dy.slbm " +
"WHERE aj.sfsc = 'N' " +
"AND aj.cbdw_bm = :cbdwbm " +
"AND (aj.ajmc like :gjz OR aj.cbjcg like :gjz) " +
"AND aj.ajzt = '1' " +
"AND (SELECT COUNT(ry.zrrbm) FROM tyyw_gg_zrrsjls ry WHERE ry.bmsah = aj.bmsah " +
"AND ry.zrrlx_dm = '0009000900001' " +
"AND ry.sfsc = 'N') > 1 " +
"AND dy.sllb = '1' AND rz.sfsc = 'N' AND dy.sfsc = 'N' )", nativeQuery = true)
//repository层的调用方法
Page<Map> findCalb(@Param("cbdwbm") String dwbm, @Param("gjz") String gjz, Pageable pageable);
注意:
1、方法传入参数中的Pageable参数,在SQL并没有使用这样一个参数,但是pageable中的page参数和sort参数会在查询时自动拼接到末尾,因此就达到了原生SQL实现分页排序的效果
2、可能会出现这样一个问题:查询出来的Page.content中,所有数据可能只有值,而不是“字段名:字段值”的key-value属性,那么这样的数据就没有任何意义,也无法让前端取得任何字段的值。
解决办法:在调用方法返回的Page类型后面加上一个Map类型即可解决。
可能大家在百度这个问题时,会发现很多回答都是在sql语句最后面加上”/#pageable/“这样一个参数,但是会发现这个并没有用,甚至还会报错:解析SQL语句出错。
(如:https://blog.csdn.net/github_34645245/article/details/81359519 中的回答) 这次问题是在工作中发现的,最重解决办法是根据本人慢慢摸索出来的,但是可能并不适用所有情况(如Mysql数据库、其他ORM框架等等均没有测试)。如果大家发现还存在其他问题,欢迎在评论区指正。
JPA或Hibernate中使用原生SQL实现分页查询、排序的更多相关文章
- 在Hibernate中使用原生SQL语句
使用原生SQL查询必须注意:程序必须选出所有的数据列才可被转换成持久化实体.假设实体在映射时有一个<many-to-one../>的关联指向另外一个实体,则SQL查询中必须返回该<m ...
- JPA或Hibernate中的
JPA执行原生SQL截断Char类型问题 在JPA的API中执行原生SQL:EntityManager.createNativeQuery(String sqlString); 传入参数是原生SQL语 ...
- django中使用原生sql
在Django中使用原生Sql主要有以下几种方式: 一:extra:结果集修改器,一种提供额外查询参数的机制 二:raw:执行原始sql并返回模型实例 三:直接执行自定义Sql ( 这种方式完全不依赖 ...
- Django中执行原生SQL语句【新编辑】
参考我的个人博客 这部分迁移到了个人博客中:Django中执行原生SQL语句 这里需要补充一下,还有一个extra方法: ret = models.Student.objects.all().extr ...
- thinkPHP框架中执行原生SQL语句的方法
这篇文章主要介绍了thinkPHP框架中执行原生SQL语句的方法,结合实例形式分析了thinkPHP中执行原生SQL语句的相关操作技巧,并简单分析了query与execute方法的使用区别,需要的朋友 ...
- tp5中使用原生sql查询总结【转】
注意事项: 1.先在database.php中配置好数据库 2.只要是数据库操作必须引用 use/think/Db;严格区分大小写. 下面是方法: public function hello5() { ...
- Atitit.Hibernate中Criteria 使用总结and 关联查询 and 按照子对象查询 o9o
Atitit.Hibernate中Criteria 使用总结and 关联查询 and 按照子对象查询 o9o 1. Criteria,,Criterion ,, 1 <2. 主要的对象黑头配置磊 ...
- Oracle/MySql/SQL Sqlserver分页查询
简述 简单概括一下Oracle,MySql,SQL Sqlserver这三个数据库的分页查询语句. Oracle分页查询 例:每页显示两条数据,现在要查询第二页,也就是第3-4条数据. 查询语句: s ...
- SQL 数据分页查询
最近学习了一下SQL的分页查询,总结了以下几种方法. 首先建立了一个表,随意插入的一些测试数据,表结构和数据如下图: 现在假设我们要做的是每页5条数据,而现在我们要取第三页的数据.(数据太少,就每页5 ...
随机推荐
- python的if判断
if 判断条件的时候,如果是多个条件一起进行判断,那么就需要逻辑运算符 并且-----------and 或者-----------or 非(取反)----not if 条件1 and 条件2 ...
- webpack优化 -- compression-webpack-plugin 开启gzip
webpack优化 -- compression-webpack-plugin 开启gzip 打包的时候开启gzip可以大大减少体积,非常适合于上线部署.下面以vue-cli2.x项目为例,介绍如何在 ...
- js基础——继承
1.实现继承:原型链 function extend1() {//父类型 this.name = "张三"; } ...
- Roslyn 使用 WriteLinesToFile 解决参数过长无法传入
在写 Roslyn 的时候,经常需要辅助编译的工具,而这些工具需要传入一些参数,在项目很大的时候,会发现自己传入的参数比微软限制控制台可以传入的参数大很多,这时就无法传入了参数 本文告诉大家如何使用 ...
- 【HTML/CSS】置换元素
置换元素: 一个内容不受CSS视觉格式化模型控制,CSS渲染模型并不考虑对此内容的渲染,且元素本身一般拥有固有尺寸(宽度,高度,宽高比)的元素,被称之为置换元素. 行内级置换和非置换元素的宽度定义 对 ...
- HashMap之红黑树
红黑树的设计,相比 jdk1.7 的 HashMap 而言,jdk1.8 最重要的就是引入了红黑树的设计,当冲突的链表长度超过 8 个的时候,链表结构就会转为红黑树结构. 01.故事的起因 “ JDK ...
- 2018-2-13-Visual-studio-C#-代码使用-NotNull
title author date CreateTime categories Visual studio C# 代码使用 NotNull lindexi 2018-2-13 17:23:3 +080 ...
- 关于MySQL中查询大数据量的情况下分页limit的性能优化
https://blog.csdn.net/weixin_37848710/article/details/80772725
- Qt4与Qt3的主要不同
Qt4与Qt3的主要不同 1)QT4 中提供了大量新控件,虽然它也保持了旧的控件,并命名为Qt3XXX,但是这样的控件没准在今后的哪个QT版本中就不被支持了,所以还是换吧,控件替换的 工作是巨大的,这 ...
- ZOJ3537 Cake
ZOJ3537 Cake 传送门:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3537 题意: 给你几何形状的蛋糕,你需要 ...