欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

oracle、mysql和SqlServer三種數(shù)據(jù)庫的分頁查詢實(shí)例

這篇文章主要介紹“oracle、MySQL和SqlServer三種數(shù)據(jù)庫的分頁查詢實(shí)例”,在日常操作中,相信很多人在oracle、mysql和SqlServer三種數(shù)據(jù)庫的分頁查詢實(shí)例問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”oracle、mysql和SqlServer三種數(shù)據(jù)庫的分頁查詢實(shí)例”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

成都創(chuàng)新互聯(lián)公司致力于網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站,成都網(wǎng)站設(shè)計(jì),集團(tuán)網(wǎng)站建設(shè)等服務(wù)標(biāo)準(zhǔn)化,推過標(biāo)準(zhǔn)化降低中小企業(yè)的建站的成本,并持續(xù)提升建站的定制化服務(wù)水平進(jìn)行質(zhì)量交付,讓企業(yè)網(wǎng)站從市場(chǎng)競(jìng)爭(zhēng)中脫穎而出。 選擇成都創(chuàng)新互聯(lián)公司,就選擇了安全、穩(wěn)定、美觀的網(wǎng)站建設(shè)服務(wù)!

MySql:

MySQL數(shù)據(jù)庫實(shí)現(xiàn)分頁比較簡(jiǎn)單,提供了 LIMIT函數(shù)。一般只需要直接寫到sql語句后面就行了。LIMIT子 句可以用來限制由SELECT語句返回過來的數(shù)據(jù)數(shù)量,它有一個(gè)或兩個(gè)參數(shù),如果給出兩個(gè)參數(shù), 第一個(gè)參數(shù)指定返回的第一行在所有數(shù)據(jù)中的位置,從0開始(注意不是1),第二個(gè)參數(shù)指定最多返回行數(shù)。例如:select * from table WHERE … LIMIT 10; #返回前10行select * from table WHERE … LIMIT 0,10; #返回前10行select * from table WHERE … LIMIT 10,20; #返回第10-20行數(shù)據(jù)

Oracle:

考慮mySql中的實(shí)現(xiàn)分頁,select * from 表名 limit 開始記錄數(shù),顯示多少條;就可以實(shí)現(xiàn)我們的分頁效果。

但是在oracle中沒有l(wèi)imit關(guān)鍵字,但是有 rownum字段

rownum是一個(gè)偽列,是oracle系統(tǒng)自動(dòng)為查詢返回結(jié)果的每行分配的編號(hào),第一行為1,第二行為2,以此類推。。。。

第一種:

復(fù)制代碼 代碼如下: SELECT * FROM ( SELECT A.*, ROWNUM RN  FROM (SELECT * FROM TABLE_NAME) A  WHERE ROWNUM <= 40)WHERE RN >= 21

其中最內(nèi)層的查詢SELECT * FROM TABLE_NAME表示不進(jìn)行翻頁的原始查詢語句。ROWNUM <= 40和RN >= 21控制分頁查詢的每頁的范圍。

上面給出的這個(gè)分頁查詢語句,在大多數(shù)情況擁有較高的效率。分頁的目的就是控制輸出結(jié)果集大小,將結(jié)果盡快的返回。在上面的分頁查詢語句中,這種考慮主要體現(xiàn)在WHERE ROWNUM <= 40這句上。

選擇第21到40條記錄存在兩種方法,一種是上面例子中展示的在查詢的第二層通過ROWNUM <= 40來控制最大值,在查詢的最外層控制最小值。而另一種方式是去掉查詢第二層的WHERE ROWNUM <= 40語句,在查詢的最外層控制分頁的最小值和最大值。

第二種:

復(fù)制代碼 代碼如下:select * from (select e.*,rownum r from (select * from emp order by sal desc) e ) e1 where e1.r>21 and e1.r<=40;

紅色部分:按照工資降序排序并查詢所有的信息。

棕色部分:得到紅色部門查詢的值,并查詢出系統(tǒng)的rownum并指定上別名。這一句就比較關(guān)鍵,起了一個(gè)過渡的作用,首先要算出rownum來對(duì)紅色部分指定上序號(hào),也可以為藍(lán)色外面部分用到這個(gè)變量。指定上查詢的開始記錄數(shù)和結(jié)束記錄的條件。

藍(lán)色部分:指定記錄從第幾條開始到第幾條結(jié)束,取出棕色部門的值來作為查詢條件的變量

總結(jié):絕大多數(shù)的情況下,第一個(gè)查詢的效率比第二個(gè)高得多。

SqlServer:

分頁方案一:(利用Not In和SELECT TOP分頁)

語句形式:

復(fù)制代碼 代碼如下: SELECT TOP 10 *

FROM TestTable

WHERE (ID NOT IN

(SELECT TOP 20 id

FROM TestTable

ORDER BY id))

ORDER BY ID

SELECT TOP 頁大小 *

FROM TestTable

WHERE (ID NOT IN

(SELECT TOP 頁大小*頁數(shù) id

FROM 表

ORDER BY id))

ORDER BY ID

分頁方案二:(利用ID大于多少和SELECT TOP分頁)

語句形式:

復(fù)制代碼 代碼如下: SELECT TOP 10 *

FROM TestTable

WHERE (ID >

(SELECT MAX(id)

FROM (SELECT TOP 20 id

FROM TestTable

ORDER BY id) AS T))

ORDER BY ID

SELECT TOP 頁大小 *

FROM TestTable

WHERE (ID >

(SELECT MAX(id)

FROM (SELECT TOP 頁大小*頁數(shù) id

FROM 表

ORDER BY id) AS T))

ORDER BY ID

分頁方案三:(利用SQL的游標(biāo)存儲(chǔ)過程分頁)

復(fù)制代碼 代碼如下: create procedure XiaoZhengGe

@sqlstr nvarchar(4000), --查詢字符串

@currentpage int, --第N頁

@pagesize int --每頁行數(shù)

as

set nocount on

declare @P1 int, --P1是游標(biāo)的id

@rowcount int

exec sp_cursoropen @P1 output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcount output

select ceiling(1.0*@rowcount/@pagesize) as 總頁數(shù)--,@rowcount as 總行數(shù),@currentpage as 當(dāng)前頁

set @currentpage=(@currentpage-1)*@pagesize+1

exec sp_cursorfetch @P1,16,@currentpage,@pagesize

exec sp_cursorclose @P1

set nocount off

其它的方案:如果沒有主鍵,可以用臨時(shí)表,也可以用方案三做,但是效率會(huì)低。

建議優(yōu)化的時(shí)候,加上主鍵和索引,查詢效率會(huì)提高。

通過SQL 查詢分析器,顯示比較:結(jié)論是:

分頁方案二:(利用ID大于多少和SELECT TOP分頁)效率最高,需要拼接SQL語句

分頁方案一:(利用Not In和SELECT TOP分頁) 效率次之,需要拼接SQL語句

分頁方案三:(利用SQL的游標(biāo)存儲(chǔ)過程分頁) 效率最差,但是最為通用

在實(shí)際情況中,要具體分析。

到此,關(guān)于“oracle、mysql和SqlServer三種數(shù)據(jù)庫的分頁查詢實(shí)例”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

網(wǎng)站欄目:oracle、mysql和SqlServer三種數(shù)據(jù)庫的分頁查詢實(shí)例
本文鏈接:http://www.chinadenli.net/article48/gpcdep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作自適應(yīng)網(wǎng)站網(wǎng)站制作網(wǎng)站內(nèi)鏈外貿(mào)網(wǎng)站建設(shè)響應(yīng)式網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)