您好:oracle查詢分頁可分為兩種情況,一種使用的是rownum ,另外一種則是使用 row_number() over(order by column_name desc)。

10年積累的成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有石龍免費(fèi)網(wǎ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ù),需要程序分頁查詢處理,模擬測試一個(gè)200萬數(shù)據(jù)量的表發(fā)現(xiàn)耗時(shí)很久,并不是業(yè)務(wù)處理耗時(shí),而且分頁查詢耗時(shí)了。oracle的分頁查詢可能大家都知道利用rownum,而且大部分公司這種分頁都是底層封裝好的了,所有平時(shí)大家使用的時(shí)候也沒注意(這次之后特意留意了一下,我們公司就是用了錯(cuò)誤的)
這兩條查詢語句看著區(qū)別不大,但是性能卻差很多。經(jīng)過測試第一種性能最好,而且隨著數(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í)行效率。
對于正確有order by語句,第二層的查詢條件WHERE ROWNUM = 20就可以被Oracle推入到內(nèi)層查詢中,這樣Oracle查詢的結(jié)果一旦超過了ROWNUM限制條件,就終止查詢將結(jié)果返回了
對于錯(cuò)誤有order by 語句,由于查詢條件where b.rowno = 11 and b.rowno = 20是存在于查詢的第三層,而Oracle無法將第三層的查詢條件推到最內(nèi)層(即使推到最內(nèi)層也沒有意義,因?yàn)樽顑?nèi)層查詢不知道b.rowno代表什么)。因此對于這個(gè)語句,Oracle最內(nèi)層返回給中間層的是所有滿足條件的數(shù)據(jù),而中間層返回給最外層的也是所有數(shù)據(jù)。數(shù)據(jù)的過濾在最外層完成,顯然這個(gè)效率要比第一個(gè)查詢低得多。
上面分析的查詢不僅僅是針對單表的簡單查詢,對于最內(nèi)層查詢是復(fù)雜的多表聯(lián)合查詢或最內(nèi)層查詢包含排序的情況一樣有效。
在Oracle中有一個(gè)方法rownum用來查詢第一行到第n行的內(nèi)容,但沒有一個(gè)合適的方法若查詢第x行到第y行的內(nèi)容,而在實(shí)際應(yīng)用中卻經(jīng)常需要查詢第x行到第y行的內(nèi)容,這時(shí)我們就需要使用rownum和子表查詢等內(nèi)容來進(jìn)行查詢,因?yàn)檫@一塊內(nèi)容屬于Oracle總的常用部分所以專門在此介紹。
在Oralce中有一個(gè)偽列rownum,其在創(chuàng)建表的時(shí)候就存在了卻不顯示,若要使用這個(gè)列可以直接調(diào)用即可,也可以對這個(gè)列添加別名來調(diào)用。
rownum只能用于顯示小于某行的數(shù)據(jù)即第一行開始到你要查詢到的那一行為止的數(shù)據(jù)。
在Oracle把查詢第幾行到第幾行的操作稱為分頁,其具體操作是通過子查詢等操作完成。
select 列名 from (select 表名.*,rownum rn from 表名)表名 ?where rn操作;
思考如下:
1.選擇所有內(nèi)容
select * from emp;
2.顯示rownum
select e.*,rownum rn from(select * from emp)e;
這一步可以精簡為下面形式,但某些情況只能用上面那種
select emp.*,rownum rn from emp;
3.查詢
select * from(select e.*,rownum rn from (select * from emp)e);
4.其他變化
在某些時(shí)候我們需要先對表的內(nèi)容進(jìn)行排序,隨后查詢第x行到第y行的內(nèi)容,這個(gè)時(shí)候有一個(gè)需要注意的點(diǎn)是rownum是在表產(chǎn)生的時(shí)候產(chǎn)生的偽列,所以使用排序會連著rownum的值進(jìn)行排序,從而達(dá)不到想要的效果。
為了解決上述這個(gè)問題,我們需要使用子表查詢即先排好序,再在新表之中顯示rownum來規(guī)避這個(gè)問題。
考慮到排序的問題,所以在上方第二步的時(shí)候使用第一種方法即select e.*,rownum rn from(select * from emp)e;,在內(nèi)表select * from emp中進(jìn)行排序可以完成在亂序中找到第x行到第y行的效果。
對于rownum來說它是oracle系統(tǒng)順序分配為從查詢返回的行的編號,返回的第一行分配的是1,第二行是2,依此類推,這個(gè)偽字段可以用于限制查詢返回的總行數(shù),且rownum不能以任何表的名稱作為前綴。
(1) rownum 對于等于某值的查詢條件
如果希望找到學(xué)生表中第一條學(xué)生的信息,可以使用rownum=1作為條件。但是想找到學(xué)生表中第二條學(xué)生的信息,使用rownum=2結(jié)果查不到數(shù)據(jù)。因?yàn)閞ownum都是從1開始,但是1以上的自然數(shù)在rownum做等于判斷是時(shí)認(rèn)為都是false條件,所以無法查到rownum = n(n1的自然數(shù))。
SQL select rownum,id,name from student where rownum=1;(可以用在限制返回記錄條數(shù)的地方,保證不出錯(cuò),如:隱式游標(biāo))
SQL select rownum,id,name from student where rownum =2;
ROWNUM ID NAME
---------- ------ ---------------------------------------------------
(2)rownum對于大于某值的查詢條件
如果想找到從第二行記錄以后的記錄,當(dāng)使用rownum2是查不出記錄的,原因是由于rownum是一個(gè)總是從1開始的偽列,Oracle 認(rèn)為rownum n(n1的自然數(shù))這種條件依舊不成立,所以查不到記錄。
查找到第二行以后的記錄可使用以下的子查詢方法來解決。注意子查詢中的rownum必須要有別名,否則還是不會查出記錄來,這是因?yàn)閞ownum不是某個(gè)表的列,如果不起別名的話,無法知道rownum是子查詢的列還是主查詢的列。
SQLselect * from(select rownum no ,id,name from student) where no2;
NO ID NAME
---------- ------ ---------------------------------------------------
3 200003 李三
4 200004 趙四
(3)rownum對于小于某值的查詢條件
rownum對于rownum 1的自然數(shù))的條件認(rèn)為是成立的,所以可以找到記錄。
SQL select rownum,id,name from student where rownum select * from (select rownum no,id,name from student where rownum=2;
NO ID NAME
---------- ------ ---------------------------------------------------
2 200002 王二
3 200003 李三
(4)rownum和排序
Oracle中的rownum的是在取數(shù)據(jù)的時(shí)候產(chǎn)生的序號,所以想對指定排序的數(shù)據(jù)去指定的rowmun行數(shù)據(jù)就必須注意了。
SQL select rownum ,id,name from student order by name;
ROWNUM ID NAME
---------- ------ ---------------------------------------------------
3 200003 李三
2 200002 王二
1 200001 張一
4 200004 趙四
可以看出,rownum并不是按照name列來生成的序號。系統(tǒng)是按照記錄插入時(shí)的順序給記錄排的號,rowid也是順序分配的。為了解決這個(gè)問題,必須使用子查詢;
SQL select rownum ,id,name from (select * from student order by name);
ROWNUM ID NAME
---------- ------ ---------------------------------------------------
1 200003 李三
2 200002 王二
3 200001 張一
4 200004 趙四
這樣就成了按name排序,并且用rownum標(biāo)出正確序號(有小到大)
可以根據(jù)下面操作進(jìn)行編寫。
1.#返回前5行 Mssql 2000分頁采用top關(guān)鍵字(20005以上版本也支持關(guān)鍵字Select top 10 * from t_order where id not in (select id from t_order where id5 )。
2.Oracle分頁采用rownum關(guān)鍵字(三層嵌套) SELECT * FROM( SELECT A.*,ROWNUM num FROM (SELECT * FROM t_order)A WHERE ROWNUM=15) WHERE num=5;--返回第5-15行數(shù)據(jù)。
3.采用row_number解析函數(shù)進(jìn)行分頁(效率更高) SELECT xx.* FROM --返回第5-15行數(shù)據(jù) 解析函數(shù)能用格式 函數(shù)over(pertion by 字段 order by 字段)。
4.Pertion 按照某個(gè)字段分區(qū) Order 按照勒個(gè)字段排序。
網(wǎng)頁名稱:oracle分頁如何使用,oracle簡單分頁
標(biāo)題來源:http://chinadenli.net/article22/dsgspjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、網(wǎng)站策劃、網(wǎng)站內(nèi)鏈、商城網(wǎng)站、微信小程序、網(wǎng)站設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)