1.使用T_BASE_PROVINCE表作為測(cè)試演示使用
我們提供的服務(wù)有:網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、五常ssl等。為超過千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的五常網(wǎng)站制作公司
2.查詢下總共數(shù)據(jù)量select count(*) from T_BASE_PROVINCE,在分頁的時(shí)候,一般會(huì)顯示總頁數(shù),需要先查詢總數(shù)據(jù)量得到總頁數(shù),總頁數(shù)=總量/每頁顯示記錄數(shù)。
3.前面的測(cè)試數(shù)據(jù)初始化完成之后,查詢前20條大概有什么樣的數(shù)據(jù)。
4.含order by排序,多一層嵌套,因?yàn)閛rder by在select之后執(zhí)行,不在里面寫的話可能會(huì)出現(xiàn)不是預(yù)期的排序結(jié)果。
如以上回答未能解決問題請(qǐng)看:
一種是利用相反的。
使用minus,即中文的意思就是減去。
一種是利用Oracle的rownum,這個(gè)是Oracle查詢自動(dòng)返回的序號(hào),一般不顯示,但是可以通過select rownum from [表名],可以看到,是從1到當(dāng)前的記錄總數(shù)。 ? ?
1.rownum分頁查詢:select t2.* from (select t1.*,rownum as rn from table_name t1 where 1=1 and rownum = page * page_size) t2 where t2.rn (page - 1) * page_size;2. row_number() over() 分頁查詢select t2.* from (select t1.*,row_number() over(order by column_name desc) as rn from table_name t1 where 1=1 )t2 where t2.rn (page-1)* page_size and t2.rn = page * page_size;
因?yàn)橐粋€(gè)功能需要讀取一個(gè)大表的所有數(shù)據(jù)做業(yè)務(wù)處理,那這樣肯定不能一次性查出所有數(shù)據(jù),需要程序分頁查詢處理,模擬測(cè)試一個(gè)200萬數(shù)據(jù)量的表發(fā)現(xiàn)耗時(shí)很久,并不是業(yè)務(wù)處理耗時(shí),而且分頁查詢耗時(shí)了。oracle的分頁查詢可能大家都知道利用rownum,而且大部分公司這種分頁都是底層封裝好的了,所有平時(shí)大家使用的時(shí)候也沒注意(這次之后特意留意了一下,我們公司就是用了錯(cuò)誤的)
這兩條查詢語句看著區(qū)別不大,但是性能卻差很多。經(jīng)過測(cè)試第一種性能最好,而且隨著數(shù)量的增大,幾乎不受影響。第二種隨著數(shù)據(jù)量的增大,查詢速度也越來越慢。表200W條數(shù)據(jù)的情況下,第一種查詢耗時(shí)基本是0.3s,第二種基本在1.3s以上。一個(gè)查詢足足差了一秒。別小看這1秒。200W條數(shù)據(jù)每次查詢1000條,查詢完也差了2000s=33分鐘.
分頁的目的就是控制輸出結(jié)果集大小,將結(jié)果盡快的返回。在上面的分頁查詢語句中,這種考慮主要體現(xiàn)在WHERE ROWNUM = 20這句上。
這是由于CBO優(yōu)化模式下,Oracle可以將外層的查詢條件推到內(nèi)層查詢中,以提高內(nèi)層查詢的執(zhí)行效率。
對(duì)于正確有order by語句,第二層的查詢條件WHERE ROWNUM = 20就可以被Oracle推入到內(nèi)層查詢中,這樣Oracle查詢的結(jié)果一旦超過了ROWNUM限制條件,就終止查詢將結(jié)果返回了
對(duì)于錯(cuò)誤有order by 語句,由于查詢條件where b.rowno = 11 and b.rowno = 20是存在于查詢的第三層,而Oracle無法將第三層的查詢條件推到最內(nèi)層(即使推到最內(nèi)層也沒有意義,因?yàn)樽顑?nèi)層查詢不知道b.rowno代表什么)。因此對(duì)于這個(gè)語句,Oracle最內(nèi)層返回給中間層的是所有滿足條件的數(shù)據(jù),而中間層返回給最外層的也是所有數(shù)據(jù)。數(shù)據(jù)的過濾在最外層完成,顯然這個(gè)效率要比第一個(gè)查詢低得多。
上面分析的查詢不僅僅是針對(duì)單表的簡(jiǎn)單查詢,對(duì)于最內(nèi)層查詢是復(fù)雜的多表聯(lián)合查詢或最內(nèi)層查詢包含排序的情況一樣有效。