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

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


咨詢
建站咨詢
