真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

oracle分頁查詢結(jié)果集重復(fù)問題&解決方法

做項(xiàng)目時(shí),無意間發(fā)現(xiàn)了分頁上的一個(gè)bug,在此記錄一下:

創(chuàng)新互聯(lián)從2013年創(chuàng)立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站建設(shè)、成都做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元岫巖做網(wǎng)站,已為上家服務(wù),為岫巖各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:13518219792

首先手動(dòng)將后臺(tái)輸出的sql語句復(fù)制進(jìn)oracle中查看,以便排查錯(cuò)誤,對(duì)比以下視圖前10條的結(jié)果集與10到20條的結(jié)果集,發(fā)現(xiàn)大部分記錄出現(xiàn)重復(fù)現(xiàn)象,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;

出現(xiàn)以上錯(cuò)誤時(shí),先是反復(fù)增加/刪除where之后的條件,不斷測(cè)試,貌似發(fā)現(xiàn)了一些端倪,錯(cuò)誤記錄都發(fā)生在count(1)的值相同時(shí),于是在網(wǎng)上好一陣搜索,可還是沒有找到解決辦法;

沒辦法了,最后還是硬著頭皮去找官網(wǎng)的一些demo,從中觀察用法,探索者、摸索著,就有了以下的版本,經(jīng)測(cè)試可以返回正確結(jié)果集,修改后如下:

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;

總結(jié):order by語句應(yīng)當(dāng)遵循條件唯一性原則,否則oracle不保證每次查詢的結(jié)果集都相同。

詳細(xì)介紹請(qǐng)參考o(jì)racle官網(wǎng):

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


文章題目:oracle分頁查詢結(jié)果集重復(fù)問題&解決方法
網(wǎng)頁網(wǎng)址:http://weahome.cn/article/jjojsc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部