oracle order by分页查询数据重复问题

今天使用手写了的分页查询,结果出现了重复数据。
问题相关sql及分析

 SELECT * FROM (
 SELECT tt.*, ROWNUM AS rowno
 FROM (SELECT * FROM XXXXX ORDER BY NAME) tt
 WHERE ROWNUM <= ${page.endIndex}) table_alias
 WHERE table_alias.rowno >= ${page.startIndex}

这个手写sql与mybatis-plus自动生成的sql一致,好像没有发现什么问题。

1.拆分sql

SELECT tt.*, ROWNUM AS rowno
 FROM (SELECT * FROM XXXXX ORDER BY NAME) tt
SELECT tt.*, ROWNUM AS rowno
 FROM (SELECT * FROM XXXXX ORDER BY NAME) tt
 WHERE ROWNUM <= ${page.endIndex}

对比上面两个sql的结果,可以发现,加上where条件之后的前endIndex+1个数据中的rownum与没有加上条件的rownum不一致,且前endIndex+1个数据并不是没有加上条件中的前endIndex+1个数据。因此问题出现在ROWNUM <= ${page.endIndex}上面。

解决方案
1.数据库order by排序不唯一,会导致最终的数据排序是不是稳定的,表现出来的结果,就是分页时会重复显示,可以排序后加上唯一值,比如id,key等(有时候好像不起作用)。

SELECT * FROM (
 SELECT tt.*, ROWNUM AS rowno
 FROM (SELECT * FROM XXXXX ORDER BY NAME,id) tt
 WHERE ROWNUM &lt;= ${page.endIndex}) table_alias
 WHERE table_alias.rowno &gt;= ${page.startIndex}
  1. 把分页条件放置到获取rownum的更外层
 SELECT * FROM (
 SELECT tt.*, ROWNUM AS rowno
 FROM (SELECT * FROM XXXXX ORDER BY NAME) tt) table_alias
 WHERE table_alias.rowno &gt;= ${page.startIndex} 
 and table_alias.rowno &lt;= ${page.endIndex}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值