在Oracle中有一個方法rownum用來查詢第一行到第n行的內容,但沒有一個合適的方法若查詢第x行到第y行的內容,而在實際應用中卻經常需要查詢第x行到第y行的內容,這時我們就需要使用rownum和子表查詢等內容來進行查詢,因為這一塊內容屬于Oracle總的常用部分所以專門在此介紹。
在豐鎮等地區,都構建了全面的區域性戰略布局,加強發展的系統性、市場前瞻性、產品創新能力,以專注、極致的服務理念,為客戶提供成都網站設計、成都網站建設 網站設計制作按需設計,公司網站建設,企業網站建設,成都品牌網站建設,成都營銷網站建設,成都外貿網站建設,豐鎮網站建設費用合理。
在Oralce中有一個偽列rownum,其在創建表的時候就存在了卻不顯示,若要使用這個列可以直接調用即可,也可以對這個列添加別名來調用。
rownum只能用于顯示小于某行的數據即第一行開始到你要查詢到的那一行為止的數據。
在Oracle把查詢第幾行到第幾行的操作稱為分頁,其具體操作是通過子查詢等操作完成。
select 列名 from (select 表名.*,rownum rn from 表名)表名 ?where rn操作;
思考如下:
1.選擇所有內容
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.其他變化
在某些時候我們需要先對表的內容進行排序,隨后查詢第x行到第y行的內容,這個時候有一個需要注意的點是rownum是在表產生的時候產生的偽列,所以使用排序會連著rownum的值進行排序,從而達不到想要的效果。
為了解決上述這個問題,我們需要使用子表查詢即先排好序,再在新表之中顯示rownum來規避這個問題。
考慮到排序的問題,所以在上方第二步的時候使用第一種方法即select e.*,rownum rn from(select * from emp)e;,在內表select * from emp中進行排序可以完成在亂序中找到第x行到第y行的效果。
因為一個功能需要讀取一個大表的所有數據做業務處理,那這樣肯定不能一次性查出所有數據,需要程序分頁查詢處理,模擬測試一個200萬數據量的表發現耗時很久,并不是業務處理耗時,而且分頁查詢耗時了。oracle的分頁查詢可能大家都知道利用rownum,而且大部分公司這種分頁都是底層封裝好的了,所有平時大家使用的時候也沒注意(這次之后特意留意了一下,我們公司就是用了錯誤的)
這兩條查詢語句看著區別不大,但是性能卻差很多。經過測試第一種性能最好,而且隨著數量的增大,幾乎不受影響。第二種隨著數據量的增大,查詢速度也越來越慢。表200W條數據的情況下,第一種查詢耗時基本是0.3s,第二種基本在1.3s以上。一個查詢足足差了一秒。別小看這1秒。200W條數據每次查詢1000條,查詢完也差了2000s=33分鐘.
分頁的目的就是控制輸出結果集大小,將結果盡快的返回。在上面的分頁查詢語句中,這種考慮主要體現在WHERE ROWNUM = 20這句上。
這是由于CBO優化模式下,Oracle可以將外層的查詢條件推到內層查詢中,以提高內層查詢的執行效率。
對于正確有order by語句,第二層的查詢條件WHERE ROWNUM = 20就可以被Oracle推入到內層查詢中,這樣Oracle查詢的結果一旦超過了ROWNUM限制條件,就終止查詢將結果返回了
對于錯誤有order by 語句,由于查詢條件where b.rowno = 11 and b.rowno = 20是存在于查詢的第三層,而Oracle無法將第三層的查詢條件推到最內層(即使推到最內層也沒有意義,因為最內層查詢不知道b.rowno代表什么)。因此對于這個語句,Oracle最內層返回給中間層的是所有滿足條件的數據,而中間層返回給最外層的也是所有數據。數據的過濾在最外層完成,顯然這個效率要比第一個查詢低得多。
上面分析的查詢不僅僅是針對單表的簡單查詢,對于最內層查詢是復雜的多表聯合查詢或最內層查詢包含排序的情況一樣有效。
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;
可以根據下面操作進行編寫。
1.#返回前5行 Mssql 2000分頁采用top關鍵字(20005以上版本也支持關鍵字Select top 10 * from t_order where id not in (select id from t_order where id5 )。
2.Oracle分頁采用rownum關鍵字(三層嵌套) SELECT * FROM( SELECT A.*,ROWNUM num FROM (SELECT * FROM t_order)A WHERE ROWNUM=15) WHERE num=5;--返回第5-15行數據。
3.采用row_number解析函數進行分頁(效率更高) SELECT xx.* FROM --返回第5-15行數據 解析函數能用格式 函數over(pertion by 字段 order by 字段)。
4.Pertion 按照某個字段分區 Order 按照勒個字段排序。
網頁標題:oracle分頁怎么查詢 oracle數據庫分頁查詢sql
當前地址:http://m.kartarina.com/article34/hgedse.html
成都網站建設公司_創新互聯,為您提供網站收錄、全網營銷推廣、小程序開發、網站內鏈、虛擬主機、用戶體驗
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯