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 ...
随机推荐
- 基于jquery读取input上传的文件内容
<script src="/static/js/jquery.js"></script> // 前端页面实现头像预览 // 当用户选中文件之后,也就是头像的 ...
- H3C 通配符掩码
- 总结thinkphp快捷查询getBy、getField、getFieldBy用法及场景
thinkphp作为国内现阶段最成熟的框架:没有之一: 不得不说是有好些特别方便的方法的: 然而如果初接触thinkphp的时候难免会被搞的有点迷茫: for example这些: getBy get ...
- UVA 1025 "A Spy in the Metro " (DAG上的动态规划?? or 背包问题??)
传送门 参考资料: [1]:算法竞赛入门经典:第九章 DAG上的动态规划 题意: Algorithm城市的地铁有 n 个站台,编号为 1~n,共有 M1+M2 辆列车驶过: 其中 M1 辆列车从 1 ...
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(13)之会员登录注册
源码下载地址:http://www.yealuo.com/Sccnn/Detail?KeyValue=c891ffae-7441-4afb-9a75-c5fe000e3d1c 会员中心,是我们与用户交 ...
- D Thanking-Bear magic
题目描述 In order to become a magical girl, Thinking-Bear are learning magic circle. He first drew a reg ...
- Linux 设备模型
在 2.5 开发循环中一个声明的目标是为内核创建一个统一的设备模型. 之前的内核没有单一的数据结 构, 使它们可以来获取关于系统如何整合的信息. 尽管缺乏信息, 有时事情也进行的不错. 新系统, 带 ...
- dotnet 启动 JIT 多核心编译提升启动性能
用2分钟提升十分之一的启动性能,通过在桌面程序启动 JIT 多核心编译提升启动性能 在 dotnet 可以通过让 JIT 进行多核心编译提升软件的启动性能,在默认托管的 ASP.NET 程序是开启的, ...
- oracle中update语句修改多个字段
如需要修改下列数据:表名为student 一般会这样写: update student set sname = '李四', sage = 20, sbirthday = to_date('2010-0 ...
- MyBatis整合Spring MVC(易百教程)
MyBatis是ibatis的升级版,作为hibernate的老对手,它是一个可以自定义SQL.存储过程和高级映射的持久层框架.与Hibernate 的主要区别就是 Mybatis 是半自动化的,而 ...