Sql Server 2012 分頁方法分析(offset and fetch)
發(fā)布日期:2022-01-14 08:02 | 文章來源:CSDN
準(zhǔn)備工作,建立測試表:Article_Detail,主要是用來存放一些文章信息,測試的時(shí)間,都是從網(wǎng)易上面轉(zhuǎn)載的新聞,同時(shí),測試表數(shù)據(jù)字段類型是比較均勻的,為了更好的測試,表結(jié)構(gòu)如下圖:
數(shù)據(jù)量:129,991 條記錄 語法分析
1. NTILE() 的分頁方法 NTILE() 方法可以用來分頁,但是應(yīng)用場景十分的狹窄,并且性能差勁,和 Row_Number() 與 offset fetch 分頁比起來沒有任何優(yōu)勢,也只有在只讀表上面分頁的話,還是比較合適的;雖然不好用,但是還能來分頁的,所以只簡單的介紹下。 語法: NTILE (integer_expression) OVER ( [ <partition_by_clause> ] < order_by_clause > )
將有序分區(qū)中的行分發(fā)到指定數(shù)目的組中。 各個(gè)組有編號(hào),編號(hào)從一開始。 對(duì)于每一個(gè)行,NTILE 將返回此行所屬的組的編號(hào)。 測試中用到的 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;
其中上述數(shù)字中的 8666 是根據(jù) RowCount / Pagesize 計(jì)算出來的,不過多介紹,可以自行參考 MSDN的 2. ROW_NUMBER() 的分頁方法 在 Sql Server 2000 之后的版本中,ROW_NUMBER() 這種分頁方式一直都是很不錯(cuò)的,比起之前的游標(biāo)分頁,性能好了很多,因?yàn)?ROW_NUMBER() 并不會(huì)引起全表掃表,但是,語法比較復(fù)雜,并且,隨著頁碼的增加,性能也越來越差。
語法 :
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
從語法可以看出來 兩個(gè)方法 后面不但能接 intege 類型的參數(shù),還能接 表達(dá)式的,比如 1*2 +3 之類的,同時(shí), Row 或者 Rows 是不區(qū)分大小寫和單復(fù)數(shù)的哦
在看測試用的 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() 的執(zhí)行計(jì)劃
2. ROW_NUMBER() 的執(zhí)行計(jì)劃
同是 Offset and Fetch 并不僅僅可以用來分頁哦,具體其他使用,大家可以自行參考 MSDN
內(nèi)容:

數(shù)據(jù)量:129,991 條記錄 語法分析
1. NTILE() 的分頁方法 NTILE() 方法可以用來分頁,但是應(yīng)用場景十分的狹窄,并且性能差勁,和 Row_Number() 與 offset fetch 分頁比起來沒有任何優(yōu)勢,也只有在只讀表上面分頁的話,還是比較合適的;雖然不好用,但是還能來分頁的,所以只簡單的介紹下。 語法: NTILE (integer_expression) OVER ( [ <partition_by_clause> ] < order_by_clause > )
將有序分區(qū)中的行分發(fā)到指定數(shù)目的組中。 各個(gè)組有編號(hào),編號(hào)從一開始。 對(duì)于每一個(gè)行,NTILE 將返回此行所屬的組的編號(hào)。 測試中用到的 Sql 語句 :
復(fù)制代碼 代碼如下:
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;
其中上述數(shù)字中的 8666 是根據(jù) RowCount / Pagesize 計(jì)算出來的,不過多介紹,可以自行參考 MSDN的 2. ROW_NUMBER() 的分頁方法 在 Sql Server 2000 之后的版本中,ROW_NUMBER() 這種分頁方式一直都是很不錯(cuò)的,比起之前的游標(biāo)分頁,性能好了很多,因?yàn)?ROW_NUMBER() 并不會(huì)引起全表掃表,但是,語法比較復(fù)雜,并且,隨著頁碼的增加,性能也越來越差。
語法 :
ROW_NUMBER ( ) OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_by_clause )
測試中用到的 Sql 語句:
復(fù)制代碼 代碼如下:
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;
OFFSET { integer_constant | offset_row_count_expression } { ROW | ROWS }
FETCH { FIRST | NEXT } { integer_constant | fetch_row_count_expression } { ROW | ROWS } ONLY
從語法可以看出來 兩個(gè)方法 后面不但能接 intege 類型的參數(shù),還能接 表達(dá)式的,比如 1*2 +3 之類的,同時(shí), Row 或者 Rows 是不區(qū)分大小寫和單復(fù)數(shù)的哦
在看測試用的 Sql 語句,真的是簡潔的不能再簡潔了,看兩遍都能記住的語法,分頁可以如此的簡潔:
復(fù)制代碼 代碼如下:
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() 的執(zhí)行計(jì)劃

2. ROW_NUMBER() 的執(zhí)行計(jì)劃


同是 Offset and Fetch 并不僅僅可以用來分頁哦,具體其他使用,大家可以自行參考 MSDN
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
相關(guān)文章
關(guān)注官方微信