首页 > 数据库技术 > 详细

解决Oracle分页使用order by排序造成分页顺序不对的问题

时间:2021-07-02 20:04:53      阅读:30      评论:0      收藏:0      [点我收藏+]
而ORACLE中,如果使用WHERE rownum<=N和ORDER BY一起出现的话,[color=red]ROWNUM优先于ORDER BY[/color]。也就是说,ORDER BY无法对所有满足条件的记录排序,只能对当前的rownum<=N中的N条记录排序。

发现第一页和第二页的数据居然一样

在测试的过程中发现数据的分页顺序不正常,但如果去掉order by之后,进行分页后的数据是正常的。

ORACLE中order by造成分页不正确原因分析

这里采用的是其中一种解决方案:order by后面加上唯一性字段(类似主键id)

主键:yhbh

select * from RE_JZQFX t
where 1=1 
$GLDWBS 
$GDSBS 
$ZXQK 
order by sjsj desc, t.yhbh 

 

解决Oracle分页使用order by排序造成分页顺序不对的问题

原文:https://www.cnblogs.com/QW-lzm/p/14964486.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!