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

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

Sql Server 2012 分頁方法分析(offset and fetch)

2024-08-31 00:57:18
字體:
來源:轉載
供稿:網友
其中 offset and fetch 最重要的新特性是 用來 分頁,既然要分析 分頁,就肯定要和之前的分頁方式來比較了,特別是 Row_Number() 了,在比較過程中,發現了蠻多,不過最重要的,通過比較本質,得出了優劣,也和大家一起分享下。

準備工作,建立測試表:Article_Detail,主要是用來存放一些文章信息,測試的時間,都是從網易上面轉載的新聞,同時,測試表數據字段類型是比較均勻的,為了更好的測試,表結構如下圖:

Sql Server 2012 分頁方法分析(offset and fetch)

內容:

Sql Server 2012 分頁方法分析(offset and fetch)


數據量:129,991 條記錄

語法分析

1. NTILE() 的分頁方法

NTILE() 方法可以用來分頁,但是應用場景十分的狹窄,并且性能差勁,和 Row_Number() 與 offset fetch 分頁比起來沒有任何優勢,也只有在只讀表上面分頁的話,還是比較合適的;雖然不好用,但是還能來分頁的,所以只簡單的介紹下。

語法:

NTILE (integer_expression) OVER ( [ <partition_by_clause> ] < order_by_clause > )
將有序分區中的行分發到指定數目的組中。 各個組有編號,編號從一開始。 對于每一個行,NTILE 將返回此行所屬的組的編號。

測試中用到的 Sql 語句 :

復制代碼 代碼如下:


set statistics time on
set statistics io on
set statistics profile on;
with #pager as
(
select ID,Title,NTILE(8666) OVER(Order By ID) as pageid from Article_Detail
)
select ID,Title from #pager where pageid=50
set statistics profile on;


其中上述數字中的 8666 是根據 RowCount / Pagesize 計算出來的,不過多介紹,可以自行參考 MSDN的

2. ROW_NUMBER() 的分頁方法

在 Sql Server 2000 之后的版本中,ROW_NUMBER() 這種分頁方式一直都是很不錯的,比起之前的游標分頁,性能好了很多,因為 ROW_NUMBER() 并不會引起全表掃表,但是,語法比較復雜,并且,隨著頁碼的增加,性能也越來越差。
語法 :
ROW_NUMBER ( ) OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_by_clause )
測試中用到的 Sql 語句:

復制代碼 代碼如下:


dbcc freeproccache
dbcc dropcleanbuffers
set statistics time on
set statistics io on
set statistics profile on;
with #pager as
(
select ID,Title,ROW_NUMBER() OVER(Order By ID) as rowid from Article_Detail
)
select ID,Title from #pager where rowid between (15 * (50-1)+1) and 15 * 50
set statistics profile off;



3. Offset and Fetch 的分頁方法

語法:
OFFSET { integer_constant | offset_row_count_expression } { ROW | ROWS }
FETCH { FIRST | NEXT } { integer_constant | fetch_row_count_expression } { ROW | ROWS } ONLY
從語法可以看出來 兩個方法 后面不但能接 intege 類型的參數,還能接 表達式的,比如 1*2 +3 之類的,同時, Row 或者 Rows 是不區分大小寫和單復數的哦
在看測試用的 Sql 語句,真的是簡潔的不能再簡潔了,看兩遍都能記住的語法,分頁可以如此的簡潔:

復制代碼 代碼如下:


dbcc freeproccache
dbcc dropcleanbuffers
set statistics time on
set statistics io on
set statistics profile on;
select ID,Title from Article_Detail order by id OFFSET (15 * (50-1)) ROW FETCH NEXT 15 rows only
set statistics profile off;


一句就搞定!
性能比較
1. NTILE() 的執行計劃

Sql Server 2012 分頁方法分析(offset and fetch)

從執行計劃中,就可以看出來,進行了一次全表掃表,兩次 Nested Loops ,還有無數其他運算,就一次全表掃表,就知道性能之差了


2. ROW_NUMBER() 的執行計劃

Sql Server 2012 分頁方法分析(offset and fetch)

從執行計劃中可以看出來, 聚集索引掃描占用了100% 的資源,但是通過 EstimateRows = 100 和 Rows = 750 可以看出來,并沒有進行全表掃描,并且IO 操作很小,所以性能還是很不錯的

3. Offset and Fetch 的 執行計劃

執行計劃只有3行,并且占用資源 100% 的IO 操作 ,EstimateRows = 100 和 Rows = 750 是和 ROW_NUMBER() 完全一樣的,但是其他的一些操作卻少了很多,也就是說,并沒有全表掃描,并降低了CPU 的消耗。

綜合比較:

在 Sql Server 2012 里面,分頁方法中,Offset and Fetch 同 ROW_NUMBER() 比較起來,無論是性能還是語法,都是有優勢的。

但是性能方面,優勢并不是太大,兩者 的 IO 消耗完全相同,只是 在 CPU 方面,Offset and Fetch 方面要好一些,但是不明顯。如果對于一個 每秒都要處理成千上萬條的分頁Sql語句的DB 來說,Offset and Fetch 在CPU 方面的優勢會比較明顯的,否則,性能的提升并不明顯。

語法方面 Offset and Fetch 則是十分的簡潔,一句搞定,比起 Row_Number() 好了太多 ~
同是 Offset and Fetch 并不僅僅可以用來分頁哦,具體其他使用,大家可以自行參考 MSDN
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产欧美日韩亚洲精品| 久久精品久久久久| 日韩欧美一区二区三区久久| 91色精品视频在线| 538国产精品一区二区在线| 777777777亚洲妇女| 日韩性生活视频| 亚洲欧美精品中文字幕在线| 国产噜噜噜噜久久久久久久久| 欧美乱大交做爰xxxⅹ性3| 国产精品久久久久影院日本| 国内揄拍国内精品| 亚洲精品自拍偷拍| 欧美精品一区三区| 日日噜噜噜夜夜爽亚洲精品| 91亚洲精品在线观看| 日韩免费精品视频| 亚洲欧洲日韩国产| 国产91在线播放九色快色| 亚洲第一在线视频| 亚洲va久久久噜噜噜久久天堂| 亚洲理论片在线观看| 97成人精品视频在线观看| 自拍偷拍亚洲精品| 国产精品一二区| 超碰日本道色综合久久综合| 狠狠色狠色综合曰曰| 国产丝袜精品视频| 777777777亚洲妇女| 成人亚洲欧美一区二区三区| 国产一区二区丝袜| 欧美老女人性生活| 激情成人中文字幕| 97香蕉久久夜色精品国产| 欧美高清视频在线播放| 亚洲欧美在线x视频| 国产精品777| 久久久亚洲福利精品午夜| 日韩精品在线观看一区二区| 亚洲免费高清视频| 日韩av免费在线看| 日韩免费精品视频| 久久精品国产久精国产一老狼| 91在线|亚洲| 欧美日韩一区二区免费在线观看| 国产精品国产三级国产aⅴ9色| 亚洲精品国产综合区久久久久久久| 奇米成人av国产一区二区三区| 久久琪琪电影院| 日韩av在线免费播放| 日韩中文字幕在线免费观看| 国产精品成人久久久久| 国产一区二区三区在线视频| 国产精品福利网| 中文字幕日韩精品有码视频| 亚洲一区二区三区乱码aⅴ| 成人av色在线观看| 欧美成人亚洲成人日韩成人| 夜夜嗨av色一区二区不卡| 亚洲欧洲黄色网| 亚洲性线免费观看视频成熟| 久久综合色88| 亚洲精品ady| 91久久久久久久| 欧美自拍视频在线| 大伊人狠狠躁夜夜躁av一区| 国产精品久久久久久av福利| 欧美理论片在线观看| 日韩欧美在线看| 国产欧美日韩亚洲精品| 久久影院资源站| 欧美理论电影在线播放| 久久精品国产一区二区三区| 国产精品久久久久福利| 国产suv精品一区二区三区88区| 色综合久综合久久综合久鬼88| 国产日韩欧美一二三区| 国产男女猛烈无遮挡91| 一本色道久久88综合日韩精品| 欧美在线视频一区二区| 久久亚洲精品一区二区| 在线视频国产日韩| 亚洲欧美日韩久久久久久| 国产深夜精品福利| 97婷婷涩涩精品一区| 亚洲综合自拍一区| 日韩中文字幕国产| 亚洲系列中文字幕| 亚洲第一色在线| 久久中文久久字幕| 深夜福利亚洲导航| 亚洲精品一区二三区不卡| 92国产精品视频| 国产精品va在线播放| 亚洲91精品在线观看| 欧美成人在线免费视频| 中文字幕精品在线视频| 一区二区三区视频观看| 成人免费在线网址| 性欧美xxxx| 国产精品69精品一区二区三区| 91在线中文字幕| 亚洲香蕉成视频在线观看| 8x海外华人永久免费日韩内陆视频| 久久中文字幕一区| 国产成人免费91av在线| 九九九久久久久久| 国内久久久精品| 国产精品网站入口| 国产精品91一区| 国产精品久久9| 亚洲图片在线综合| 国产精品99一区| 狠狠色狠狠色综合日日五| 搡老女人一区二区三区视频tv| 久久精品亚洲94久久精品| 日韩欧美在线国产| 午夜精品久久久久久久99热| 亚洲一区999| 国产日韩中文字幕在线| 欧美激情一级欧美精品| 亚洲第一级黄色片| 国产自产女人91一区在线观看| 久久精品一本久久99精品| 国产999精品久久久| 国产亚洲精品美女| 欧美性猛交xxxx黑人| 精品久久久精品| 按摩亚洲人久久| 欧美日韩亚洲视频| 4444欧美成人kkkk| 国产香蕉97碰碰久久人人| 91av福利视频| 国产精品私拍pans大尺度在线| 日韩在线观看免费全集电视剧网站| 精品国产乱码久久久久久婷婷| 欧美高清videos高潮hd| 日本精品中文字幕| 国产丝袜精品视频| 日韩av在线免费观看| 亚洲第一福利网站| 成人av在线网址| 国产日韩精品在线| 久久精品国产清自在天天线| 91精品综合久久久久久五月天| 亚洲视频在线免费观看| 日韩一级裸体免费视频| 中日韩美女免费视频网址在线观看| 亚洲一区www| 成人免费网站在线看| 92看片淫黄大片看国产片| 久久久精品在线观看| 欧美日韩中文字幕综合视频| 国产精品一区二区电影| 国产在线高清精品| 亚洲网站视频福利| 久久天天躁夜夜躁狠狠躁2022| 欧美影院在线播放| 亚洲天堂久久av| 在线播放国产精品| 日韩激情视频在线播放| 色老头一区二区三区在线观看| 久久97精品久久久久久久不卡| 97超级碰在线看视频免费在线看|