189 8069 5689

oracle分页查询结果集重复问题&解决方法-创新互联

做项目时,无意间发现了分页上的一个bug,在此记录一下:

创新互联长期为上1000+客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为钦州企业提供专业的成都网站建设、成都做网站,钦州网站改版等技术服务。拥有十年丰富建站经验和众多成功案例,为您定制开发。

首先手动将后台输出的sql语句复制进oracle中查看,以便排查错误,对比以下视图前10条的结果集与10到20条的结果集,发现大部分记录出现重复现象,SQL语句如下:

--前10条记录 select *   from (select row_.*, rownum rownum_           from (select t.idcard, count(1)                   from sampling.v_unvoucher_blacklist t                  where 1 = 1                  group by t.idcard                  order by count(1) asc) row_          where rownum <= 10)  where rownum_ > 0; --第11条-第20条记录 select *   from (select row_.*, rownum rownum_           from (select t.idcard, count(1)                   from sampling.v_unvoucher_blacklist t                  where 1 = 1                  group by t.idcard                  order by count(1) asc) row_          where rownum <= 20)  where rownum_ > 10;

出现以上错误时,先是反复增加/删除where之后的条件,不断测试,貌似发现了一些端倪,错误记录都发生在count(1)的值相同时,于是在网上好一阵搜索,可还是没有找到解决办法;

没办法了,最后还是硬着头皮去找官网的一些demo,从中观察用法,探索者、摸索着,就有了以下的版本,经测试可以返回正确结果集,修改后如下:

select *   from (select row_1.*, rownum rownum_           from (select * from (select t.idcard idcard, count(1) total                   from sampling.v_unvoucher_blacklist t                  where 1 = 1                  group by t.idcard)                  order by total,rownum asc) row_1          where rownum <= 10)  where rownum_ > 0;

总结:order by语句应当遵循条件唯一性原则,否则oracle不保证每次查询的结果集都相同。

详细介绍请参考oracle官网:

http://www.oracle.com/technetwork/issue-archive/2006/06-sep/o56asktom-086197.html

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网页名称:oracle分页查询结果集重复问题&解决方法-创新互联
文章URL:http://cdxtjz.cn/article/dccjie.html

其他资讯