新聞中心
Oracle數(shù)據(jù)庫是當(dāng)前業(yè)內(nèi)最為流行的關(guān)系型數(shù)據(jù)庫之一,它具有高效、穩(wěn)定、安全等優(yōu)秀的品質(zhì),因此在數(shù)據(jù)存儲和具體應(yīng)用方面受到了廣泛的關(guān)注和應(yīng)用。在使用過程中,有一個非常常見的需求,那就是需要對大量數(shù)據(jù)進(jìn)行分頁查詢,實現(xiàn)查詢結(jié)果快速呈現(xiàn)和瀏覽。以下將介紹如何使用Oracle數(shù)據(jù)庫實現(xiàn)分頁SQL查詢。

十載的北侖網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。全網(wǎng)整合營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整北侖建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“北侖網(wǎng)站設(shè)計”,“北侖網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。
一、分頁查詢的基本原理
在進(jìn)行分頁查詢之前,我們需要了解分頁查詢的基本原理,那就是基于當(dāng)前頁碼和每頁數(shù)據(jù)條數(shù)確定查詢語句中offset和limit的參數(shù)。比如我們需要查詢第3頁每頁10條數(shù)據(jù),那么查詢語句的參數(shù)就應(yīng)該是offset=20和limit=10,具體SQL語句如下所示:
SELECT * FROM TABLE_NAME WHERE ROWNUM ]]> 20 AND ROWNUM
其中,ROWNUM是Oracle數(shù)據(jù)庫中一個偽列,表示返回結(jié)果集中該行的行號。因此,上述SQL語句就表示查詢TABLE_NAME表中第21~30條數(shù)據(jù),也就是第3頁數(shù)據(jù)。
二、使用Oracle數(shù)據(jù)庫實現(xiàn)分頁SQL查詢
實現(xiàn)分頁查詢的方法有多種,下面將分別介紹其中兩種方法。
1.使用ROWNUM實現(xiàn)分頁查詢
如上所述,使用ROWNUM實現(xiàn)分頁查詢的方法已經(jīng)非常成熟和廣泛應(yīng)用,它的基本原理就是通過查詢語句中的ROWNUM偽列獲取每行的行號,再通過offset和limit參數(shù)確定需要查詢的數(shù)據(jù)范圍。具體實現(xiàn)步驟如下所示:
(1)我們需要查詢表中所有數(shù)據(jù)的總數(shù),用于計算總頁數(shù)和當(dāng)前查詢頁的數(shù)據(jù)范圍。
SELECT COUNT(*) FROM TABLE_NAME;
(2)查詢指定頁碼的數(shù)據(jù),并根據(jù)OFFSET和LIMIT參數(shù)確定數(shù)據(jù)范圍。
SELECT * FROM TABLE_NAME WHERE ROWNUM ]]> ((PAGE_NO – 1) * PAGE_SIZE) AND ROWNUM
其中,PAGE_NO為當(dāng)前查詢頁碼,PAGE_SIZE為每頁數(shù)據(jù)條數(shù),可以通過前臺進(jìn)行傳遞。
(3)在分頁查詢時,通常需要按照指定的列進(jìn)行排序,因此我們需要在查詢語句中加入ORDER BY子句,比如以下查詢語句就表示按照ID列降序排列。
SELECT * FROM TABLE_NAME WHERE ROWNUM ]]> ((PAGE_NO – 1) * PAGE_SIZE) AND ROWNUM
2.使用FETCH和OFFSET實現(xiàn)分頁查詢
除了使用ROWNUM實現(xiàn)分頁查詢外,Oracle數(shù)據(jù)庫還支持使用FETCH和OFFSET實現(xiàn)分頁查詢,這種方法在12c版本以后才支持。使用FETCH和OFFSET實現(xiàn)分頁查詢的基本原理就是將查詢結(jié)果從客戶端獲取,而不是在服務(wù)器端進(jìn)行分頁。具體實現(xiàn)步驟如下所示:
(1)通過SELECT語句查詢所有數(shù)據(jù),并進(jìn)行排序。
SELECT * FROM TABLE_NAME ORDER BY ID DESC;
(2)在SQL語句中使用FETCH和OFFSET關(guān)鍵字,獲取指定頁碼的數(shù)據(jù)。
SELECT * FROM TABLE_NAME ORDER BY ID DESC FETCH FIRST PAGE_SIZE ROWS ON OFFSET OFFSET_VALUE;
其中,PAGE_SIZE為每頁數(shù)據(jù)條數(shù),OFFSET_VALUE為該頁數(shù)據(jù)的起始偏移值,可以通過計算得到。
三、
本文針對如何使用Oracle數(shù)據(jù)庫實現(xiàn)分頁SQL查詢進(jìn)行了詳細(xì)的介紹,介紹了兩種方法:使用ROWNUM和使用FETCH和OFFSET。使用ROWNUM方法已經(jīng)非常成熟和廣泛應(yīng)用,而使用FETCH和OFFSET方法需要注意Oracle數(shù)據(jù)庫的版本號。在實際應(yīng)用中,我們可以根據(jù)實際情況選擇不同的方法,以達(dá)到更佳的查詢效果。
相關(guān)問題拓展閱讀:
- 求一個通用ORACLE存儲過程,實現(xiàn)分頁和查詢?
求一個通用ORACLE存儲過程,實現(xiàn)分頁和查詢?
數(shù)據(jù)庫中定義一個包,定義游標(biāo)類型,比如可以這樣:
create
or
replace
package
package_name
as
type
outcur
is
ref
cursor;
end
;
然后存儲過程返回結(jié)果集喊頃:
create
procedure
ttt(
p_cur
out
package_name.outcur)
as
begin
open
p_cur
for
select
…;
end;
這樣就可以返回結(jié)果集了.
如果數(shù)據(jù)量太大,返回全部記錄再通過程序控制分頁意義不大,效率同樣太低,樓租坦上的那個rownbr我沒聽過,只知道rownum,但這個偽列是不能滿足分頁要求的,如果數(shù)據(jù)量非常弊滲桐大,快速分頁的話可以考慮用rowid這個列,
試試
select
rowid
from
任意表;
能看出結(jié)果了吧.剩下的自己想辦法吧.
create
or
replace
package
Tools
is
type
ResultData
is
ref
cursor;
procedure
sp_Page(p_PageSize
int,
–每頁記錄數(shù)
p_PageNo
int,
–當(dāng)前頁碼,從
開始
p_SqlSelect
varchar2,
–查詢語句,含排梁芹序部分
p_SqlCount
varchar2,
–獲取記錄段巧總數(shù)的查詢語句
p_OutRecordCount
out
int,–返回總記錄數(shù)
p_OutCursor
out
ResultData);
end
Tools;
create
or
replace
package
body
Tools
is
procedure
sp_Page(p_PageSize
int,
–每頁記錄數(shù)
p_PageNo
int,
–當(dāng)前頁碼握渣鍵,從
開始
p_SqlSelect
varchar2,
–查詢語句,含排序部分
p_SqlCount
varchar2,
–獲取記錄總數(shù)的查詢語句
p_OutRecordCount
out
int,–返回總記錄數(shù)
p_OutCursor
out
ResultData)
as
v_sql
varchar2(3000);
v_count
int;
v_heiRownum
int;
v_lowRownum
int;
begin
—-取記錄總數(shù)
execute
immediate
p_SqlCount
into
v_count;
p_OutRecordCount
:=
v_count;
—-執(zhí)行分頁查詢
v_heiRownum
:=
p_PageNo
*
p_PageSize;
v_lowRownum
:=
v_heiRownum
–
p_PageSize
+1;
v_sql
:=
‘SELECT
*
FROM
(
SELECT
A.*,
rownum
rn
FROM
(‘||
p_SqlSelect
||’)
A
WHERE
rownum
=
‘
||
to_char(v_lowRownum)
;
–注意對rownum別名的使用,之一次直接用rownum,第二次一定要用別名rn
OPEN
p_OutCursor
FOR
v_sql;
end
sp_Page;
end
Tools;
oracle數(shù)據(jù)庫分頁sql的介紹就聊到這里吧,感謝你花時間閱讀本站內(nèi)容,更多關(guān)于oracle數(shù)據(jù)庫分頁sql,如何使用Oracle數(shù)據(jù)庫實現(xiàn)分頁SQL查詢?,求一個通用ORACLE存儲過程,實現(xiàn)分頁和查詢?的信息別忘了在本站進(jìn)行查找喔。
香港服務(wù)器選創(chuàng)新互聯(lián),2H2G首月10元開通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務(wù)提供商,擁有超過10年的服務(wù)器租用、服務(wù)器托管、云服務(wù)器、虛擬主機(jī)、網(wǎng)站系統(tǒng)開發(fā)經(jīng)驗。專業(yè)提供云主機(jī)、虛擬主機(jī)、域名注冊、VPS主機(jī)、云服務(wù)器、香港云服務(wù)器、免備案服務(wù)器等。
文章題目:如何使用Oracle數(shù)據(jù)庫實現(xiàn)分頁SQL查詢?(oracle數(shù)據(jù)庫分頁sql)
文章分享:http://m.fisionsoft.com.cn/article/ccsgepp.html


咨詢
建站咨詢
