亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

oracle,mysql,SqlServer三種數據庫的分頁查詢的實例

2024-08-31 00:56:20
字體:
來源:轉載
供稿:網友

MySql:

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

Oracle:

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

但是在oracle中沒有limit關鍵字,但是有 rownum字段

rownum是一個偽列,是oracle系統自動為查詢返回結果的每行分配的編號,第一行為1,第二行為2,以此類推。。。。

第一種:

復制代碼 代碼如下:


SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= 40
)
WHERE RN >= 21


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

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

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

第二種:

復制代碼 代碼如下:


select * from (select e.*,rownum r from (select * from emp order by sal desc) e ) e1 where e1.r>21 and e1.r<=40;


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

棕色部分:得到紅色部門查詢的值,并查詢出系統的rownum并指定上別名。這一句就比較關鍵,起了一個過渡的作用,首先要算出rownum來對紅色部分指定上序號,也可以為藍色外面部分用到這個變量。指定上查詢的開始記錄數和結束記錄的條件。

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

總結:絕大多數的情況下,第一個查詢的效率比第二個高得多。

SqlServer:

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

語句形式:

復制代碼 代碼如下:


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 頁大小*頁數 id

FROM 表

ORDER BY id))

ORDER BY ID


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

語句形式:

復制代碼 代碼如下:


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 頁大小*頁數 id

FROM 表

ORDER BY id) AS T))

ORDER BY ID


分頁方案三:(利用SQL的游標存儲過程分頁)

復制代碼 代碼如下:


create procedure XiaoZhengGe

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

@currentpage int, --第N頁

@pagesize int --每頁行數

as

set nocount on

declare @P1 int, --P1是游標的id

@rowcount int

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

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

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

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

exec sp_cursorclose @P1

set nocount off


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

建議優化的時候,加上主鍵和索引,查詢效率會提高。

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

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

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

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

在實際情況中,要具體分析。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久久久久久久久| 久久久之久亚州精品露出| 国产亚洲一级高清| 久久久久久久久国产精品| 2019中文字幕在线免费观看| 久久综合伊人77777蜜臀| 韩剧1988在线观看免费完整版| 亚洲娇小xxxx欧美娇小| 精品中文字幕在线2019| 亚洲一区www| 欧亚精品在线观看| 欧美激情2020午夜免费观看| 精品视频久久久久久| 欧美激情亚洲综合一区| 国产精品一区二区电影| 欧美日韩在线观看视频| 亚洲摸下面视频| 久久精品一偷一偷国产| 欧美放荡办公室videos4k| 欧美xxxx综合视频| 亚洲一区二区三区在线免费观看| 国产精品精品国产| 91av在线视频观看| 日本欧美一级片| 97精品国产aⅴ7777| 亚洲欧美三级伦理| 亚洲国产精品国自产拍av秋霞| 久久精品成人欧美大片古装| 色综合色综合网色综合| 国产成人精品综合| 亚洲欧洲在线免费| 亚洲天堂av高清| 亚洲人成电影在线播放| 成人羞羞国产免费| 蜜臀久久99精品久久久无需会员| 欧美在线视频免费| 欧美激情亚洲视频| 欧美极品美女电影一区| 成人欧美一区二区三区黑人孕妇| 久久99精品久久久久久青青91| 中文字幕日韩精品在线| 亚洲曰本av电影| 91久久精品国产91久久| 美女视频黄免费的亚洲男人天堂| 久久久午夜视频| 久久97久久97精品免视看| 久久久成人精品| 中文字幕欧美专区| 久久久久久久久国产精品| 91成品人片a无限观看| 国产一区av在线| 日韩欧美国产成人| 日韩电影视频免费| 免费av在线一区| 91九色精品视频| 精品国偷自产在线| 亚洲精品之草原avav久久| 国产日产久久高清欧美一区| 日本精品视频网站| 久久久国产一区二区| 国产精品情侣自拍| 日本亚洲欧洲色| 日韩av一卡二卡| 久久国产精品久久久久| 精品国产自在精品国产浪潮| 欧美日韩色婷婷| 精品一区二区三区三区| 中文字幕国产亚洲2019| 美女撒尿一区二区三区| 国产精品成久久久久三级| 97在线免费观看视频| 国产精品老女人精品视频| 日韩电影中文字幕一区| 亚洲午夜精品视频| 久久综合免费视频| 久久韩国免费视频| 26uuu另类亚洲欧美日本老年| 国产乱人伦真实精品视频| 久久91亚洲精品中文字幕| 亚洲国产成人av在线| 伊人久久男人天堂| 欧美超级乱淫片喷水| www.日本久久久久com.| 日本道色综合久久影院| 亚洲第一天堂av| 亚洲欧美精品在线| 国产精品av免费在线观看| 欧美精品少妇videofree| 日韩美女写真福利在线观看| 日韩中文字幕在线看| 亚洲激情视频网| 国产亚洲成av人片在线观看桃| 国产一区二区日韩精品欧美精品| 91高潮精品免费porn| 欧美电影免费观看高清完整| 久久99精品久久久久久琪琪| 懂色av影视一区二区三区| 亚洲欧美在线看| 欧美精品www| 精品成人在线视频| 亚洲va久久久噜噜噜久久天堂| 日韩电视剧免费观看网站| 亚洲激情久久久| 亚洲综合在线中文字幕| 亚洲直播在线一区| 久久777国产线看观看精品| 北条麻妃99精品青青久久| 亚洲日本成人网| 97国产精品免费视频| 欧美伦理91i| 91高清在线免费观看| 国产午夜精品免费一区二区三区| 国产91九色视频| 久久99精品久久久久久青青91| 色偷偷偷综合中文字幕;dd| 亚洲黄一区二区| 福利视频导航一区| 欧美放荡办公室videos4k| 俺去亚洲欧洲欧美日韩| 亚洲精品在线91| 久久综合网hezyo| 欧美精品激情在线| www.日韩欧美| 国内偷自视频区视频综合| 欧美视频免费在线| 欧美国产中文字幕| 色噜噜亚洲精品中文字幕| 久久精品视频在线| 亚洲欧洲一区二区三区在线观看| 欧美日韩电影在线观看| 亚洲午夜久久久久久久| 国产成人一区二区三区| 538国产精品视频一区二区| 性欧美办公室18xxxxhd| 日韩小视频在线| 国产精品美女主播| 欧美老女人性生活| 日韩中文在线观看| 欧美视频在线观看 亚洲欧| 亚洲亚裔videos黑人hd| 久久久亚洲福利精品午夜| 欧美自拍视频在线| 日韩精品极品毛片系列视频| 91深夜福利视频| 91久久精品国产91久久性色| 最好看的2019的中文字幕视频| 日韩精品999| 亚洲精品美女在线观看播放| 亚洲韩国青草视频| 国产成人精品一区二区在线| 国产一区二区三区在线免费观看| 日韩精品中文字幕在线播放| 国产欧美一区二区白浆黑人| 在线成人一区二区| 亚洲电影免费观看高清完整版在线| 久久视频在线直播| 91精品久久久久久久久久久久久久| 久久网福利资源网站| 日韩欧美精品在线观看| 欧美激情精品久久久久| 国产极品jizzhd欧美| 午夜精品一区二区三区视频免费看| 亚洲国产精品电影在线观看| 久久精品亚洲一区|