Oracle實(shí)現(xiàn)分頁三種不同的方式
前言
Oracle的三層分頁指的是在進(jìn)行分頁查詢時,使用三種不同的方式來實(shí)現(xiàn)分頁效果,分別是使用ROWNUM、使用OFFSET和FETCH、使用ROW_NUMBER() OVER()
1.使用ROWNUM
ROWNUM是Oracle中一個偽列,它用于表示返回的行的序號。使用ROWNUM進(jìn)行分頁查詢的方法是在SELECT語句中加入WHERE子句,并在WHERE子句中指定ROWNUM的取值范圍,例如:
SELECT * FROM ( SELECT a.*, ROWNUM r FROM my_table a WHERE ROWNUM <= 30 ) WHERE r >= 20;
上述查詢語句的意思是查詢my_table表中的前30條記錄,然后在這30條記錄中取出第20到第30條記錄作為結(jié)果返回。使用ROWNUM進(jìn)行分頁查詢的優(yōu)點(diǎn)是簡單易懂,缺點(diǎn)是在查詢大量數(shù)據(jù)時性能較差。
2.使用OFFSET和FETCH
OFFSET和FETCH是Oracle 12c引入的語法,它們可以更方便地實(shí)現(xiàn)分頁查詢。使用OFFSET和FETCH進(jìn)行分頁查詢的方法是在SELECT語句中加入OFFSET和FETCH子句,例如:
SELECT * FROM my_table ORDER BY my_column OFFSET 20 ROWS FETCH NEXT 10 ROWS ONLY;
上述查詢語句的意思是對my_table表按照my_column列進(jìn)行排序,然后取出從第21條記錄開始的10條記錄作為結(jié)果返回。使用OFFSET和FETCH進(jìn)行分頁查詢的優(yōu)點(diǎn)是簡單方便,缺點(diǎn)是只有在Oracle 12c及以上版本中才能使用。
3.使用ROW_NUMBER() OVER()
ROW_NUMBER() OVER()是Oracle中一種用于計算行號的函數(shù)。使用ROW_NUMBER() OVER()進(jìn)行分頁查詢的方法是在SELECT語句中加入ROW_NUMBER() OVER()函數(shù),并在WHERE子句中指定ROW_NUMBER() OVER()的取值范圍,例如:
SELECT * FROM ( SELECT a.*, ROW_NUMBER() OVER (ORDER BY my_column) r FROM my_table a ) WHERE r BETWEEN 21 AND 30;
上述查詢語句的意思是對my_table表按照my_column列進(jìn)行排序,然后取出第21到第30條記錄作為結(jié)果返回。使用ROW_NUMBER() OVER()進(jìn)行分頁查詢的優(yōu)點(diǎn)是靈活性高,可以實(shí)現(xiàn)各種不同的分頁方式,缺點(diǎn)是語法較為復(fù)雜。
總結(jié)
到此這篇關(guān)于Oracle實(shí)現(xiàn)分頁三種不同的方式的文章就介紹到這了,更多相關(guān)Oracle分頁方式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
處理Oracle 監(jiān)聽文件listener.log問題
這篇文章主要介紹了處理Oracle 監(jiān)聽文件listener.log問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12在window操作系統(tǒng)上安裝Oracle10g圖文教程
Oracle10g是Oracle公司出的一個比較輕量版的數(shù)據(jù)庫,在window系統(tǒng)上安裝比較方便,這篇文章主要介紹了在window操作系統(tǒng)上安裝Oracle10g圖文教程,需要的朋友可以參考下2017-02-02Oracle中簡單查詢、限定查詢、數(shù)據(jù)排序SQL語句范例和詳細(xì)注解
這篇文章主要介紹了Oracle中簡單查詢、限定查詢、數(shù)據(jù)排序SQL語句范例和詳細(xì)注解,對查詢語法一并做了介紹,需要的朋友可以參考下2014-07-07巧妙解決Oracle NClob讀寫問題(經(jīng)驗(yàn)分享)
下面小編就為大家?guī)硪黄擅罱鉀QOracle NClob讀寫問題(經(jīng)驗(yàn)分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10Oracle出現(xiàn)ora-12154無法解析指定連接標(biāo)識符的解決方法
這篇文章主要為大家詳細(xì)介紹了Oracle出現(xiàn)ora-12154無法解析指定連接標(biāo)識符的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10在oracle 數(shù)據(jù)庫查詢的select 查詢字段中關(guān)聯(lián)其他表的方法
在實(shí)際開發(fā)過程中,特別是在做數(shù)據(jù)查詢的時候,能夠根據(jù)動態(tài)生成的sql語句將查詢的結(jié)果轉(zhuǎn)化并返回到業(yè)務(wù)處理邏輯(或頁面展示出來)能大大的減輕業(yè)務(wù)邏輯的處理復(fù)雜度。2009-08-08Oracle數(shù)學(xué)相關(guān)函數(shù)小結(jié)
這篇文章主要介紹了Oracle數(shù)學(xué)相關(guān)函數(shù),實(shí)例總結(jié)了Oracle常用的數(shù)學(xué)相關(guān)函數(shù)并給出了相應(yīng)用法示例,需要的朋友可以參考下2016-03-03