日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
如何使用Oracle數(shù)據(jù)庫(kù)實(shí)現(xiàn)分頁(yè)SQL查詢?(oracle數(shù)據(jù)庫(kù)分頁(yè)sql)

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