oracle分页查询数据重复问题的解决
2012-08-16 10:55
477 查看
在oracle分页查询中,我们采用类似以下所示的公认的比较高效的数据库分页查询语句(Effective Oracle by
Design中有描述、众多oracle使用者也做过测试)。
写道
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= n)
WHERE RN > m
这里的ROWNUM是一个伪列,它是oracle为查询结果所编的一个号,第一行的 ROWNUM为1,第二行为2,以此类
推。
因为oracle是按块进行读取数据的,如果数据按顺序存储,则可能使读取出来的数据是按顺序的,给用户误解
为默认排序。事实上,oracle没有进行任何排序操作,如果sql没有要求排序,oracle会顺序的从数据块中读取
符合条件的数据返回到客户端。所以在没有使用排序sql的时候,分页返回的数据可能是按顺序的,也可能是杂
乱无章的,这都取决与数据的存储位置。在分页查询过程中,如果数据的物理位置发生了改变,就可能会引起
分页数据重复的现象。
所以,要正确使用分页查询,sql语句中必须有排序条件。
但是,在有排序条件的时候,仍然会出现数据重复的现象,这是为什么呢?
通过了解oracle的排序机理就会明白,出现这种情况的原因是因为排序列值的不唯一性。 Oracle这里使用的排
序算法不具有稳定性,也就是说,对于键值相等的数据,这种算法完成排序后,不保证这些键值相等的数据保
持排序前的顺序。
解决的方法是在后边增加一个唯一性列,比如主键。
所以解决方法如下(两个条件必须同时满足):
1.sql语句中需要有排序条件。
2.排序条件如果没有唯一性,那么必须在后边跟上一个唯一性的条件,比如主键 。
Design中有描述、众多oracle使用者也做过测试)。
写道
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= n)
WHERE RN > m
这里的ROWNUM是一个伪列,它是oracle为查询结果所编的一个号,第一行的 ROWNUM为1,第二行为2,以此类
推。
因为oracle是按块进行读取数据的,如果数据按顺序存储,则可能使读取出来的数据是按顺序的,给用户误解
为默认排序。事实上,oracle没有进行任何排序操作,如果sql没有要求排序,oracle会顺序的从数据块中读取
符合条件的数据返回到客户端。所以在没有使用排序sql的时候,分页返回的数据可能是按顺序的,也可能是杂
乱无章的,这都取决与数据的存储位置。在分页查询过程中,如果数据的物理位置发生了改变,就可能会引起
分页数据重复的现象。
所以,要正确使用分页查询,sql语句中必须有排序条件。
但是,在有排序条件的时候,仍然会出现数据重复的现象,这是为什么呢?
通过了解oracle的排序机理就会明白,出现这种情况的原因是因为排序列值的不唯一性。 Oracle这里使用的排
序算法不具有稳定性,也就是说,对于键值相等的数据,这种算法完成排序后,不保证这些键值相等的数据保
持排序前的顺序。
解决的方法是在后边增加一个唯一性列,比如主键。
所以解决方法如下(两个条件必须同时满足):
1.sql语句中需要有排序条件。
2.排序条件如果没有唯一性,那么必须在后边跟上一个唯一性的条件,比如主键 。
相关文章推荐
- oracle分页查询数据重复问题的解决
- oracle分页查询数据重复问题的解决
- 教您如何解决oracle分页查询数据重复问题
- 如何解决oracle分页查询数据重复问题
- Oracle Order By后导分页数据重复问题解决办法。
- oracle分页查询数据重复问题、分页排序陷阱
- oracle分页查询数据重复问题
- oracle分页查询数据重复问题
- oracle 分页查询数据重复问题
- Oracle分页查询排序数据重复问题
- oracle分页查询结果集重复问题&解决方法
- oracle分页查询数据重复问题
- 关于oracle重复数据合并以及.前面加0问题的解决
- Oracle查询重复记录,分页和去掉重复数据的查询语句
- 关于 Oracle分页数据重复的问题
- SQL分页排序的实现与分页数据重复问题——以Oracle rownum为例
- oracle排序,出现页数不同数据却重复问题的原因及解决办法
- SQL分页排序的实现与分页数据重复问题——以Oracle rownum为例
- mysql分页加排序数据重复问题解决方案
- oracle中rowid解决数据重复的问题