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取数据机制和环境有关,因此它是带有不确定性排序。