oracle中带order by 的分页问题

oracle中分页时如果SQL中有排序,务必要保证排序字段的唯一确定性。

比如 select * from td_product order by productName,status wherer rownum >10

 

如果 productName和status不具唯一性(针对于当前表搜索出来的所有数据,和联合主键一个意思),这时候就有可能在第一页出现过的数据,在第二页再次出现。这时候可以在order by 最后加一个主键或者带有唯一性质的字段。这样即不影响业务上的排序,也可以保证分页正确性。比如:

select * from tdProduct order by productName,status,productId wherer rownum >10

 

出现这个情况的原因是,productName和status不具唯一性。考虑一种极端情况。所有productName和status都是一模一样的。oracle会从第11个数据开始取。问题在于每次取出来的数据顺序不一定一样,这跟oracle取数据机制和环境有关,因此它是带有不确定性排序。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值