做項(xiàng)目時(shí),無(wú)意間發(fā)現(xiàn)了分頁(yè)上的一個(gè)bug,在此記錄一下:
首先手動(dòng)將后臺(tái)輸出的sql語(yǔ)句復(fù)制進(jìn)oracle中查看,以便排查錯(cuò)誤,對(duì)比以下視圖前10條的結(jié)果集與10到20條的結(jié)果集,發(fā)現(xiàn)大部分記錄出現(xiàn)重復(fù)現(xiàn)象,SQL語(yǔ)句如下:
--前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ǔ)句應(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
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
分享名稱:oracle分頁(yè)查詢結(jié)果集重復(fù)問題&解決方法-創(chuàng)新互聯(lián)
分享URL:http://www.2m8n56k.cn/article4/dccjie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)、定制網(wǎng)站、網(wǎng)站收錄、面包屑導(dǎo)航、商城網(wǎng)站、網(wǎng)站維護(hù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容