做項(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