一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - Sql Server 2012 分頁方法分析(offset and fetch)

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

2019-12-23 16:25MSSQL教程網 Sql Server

最近在分析 Sql Server 2012 中 offset and fetch 的新特性,發現 offset and fetch 無論語法的簡潔還是功能的強大,都是相當相當不錯的

其中 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 的 執行計劃

Sql Server 2012 分頁方法分析(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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99热这里只有精品免费 | 日本艳鉧动漫1~6完整版在 | 好吊色青青青国产综合在线观看 | 日韩高清一区二区三区不卡 | 精品一区二区三区 不卡高清 | 边摸边吃奶又黄激烈视频韩国 | 成人小视频在线观看免费 | 耽美肉文高h | 欧美xxxxx69| 好吊色永久免费视频大全 | 楚乔传第二部免费播放电视连续剧 | 亚洲高清中文字幕一区二区三区 | 好男人在线观看免费高清2019韩剧 | 国四虎影永久 | 无码区国产区在线播放 | bedfriend泰剧全集免费观看 | 香蕉视频在线观看网址 | 91混血大战上海双胞胎 | 欧美男男gaygaysxxx | 四虎国产成人亚洲精品 | 国产精品林美惠子在线观看 | 性派对videofreeparty | 夫妻性生活影院 | 福利国模私拍视频在线观看 | 6个老师的尿奴 | 亚洲图片一区二区 | japanese在线观看 | 2021最新国产成人精品视频 | 图片亚洲va欧美va国产综合 | 国产福利资源 | 国产色视频网站 | 亚洲天堂一区二区在线观看 | 91精品国产亚洲爽啪在线影院 | 亚洲国产第一区二区三区 | 亚洲精品一区二区三区在线看 | 日本乱子 | 99国内精品久久久久久久黑人 | 四虎在线网站 | 87影院在线观看视频在线观看 | 亚洲国产精品成人午夜在线观看 | 国产午夜精品久久理论片小说 |