网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

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://bjjierui.cn/article/dccjie.html

其他资讯