久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

SQL server有哪些分頁方法

162次閱讀
沒有評論

共計 2959 個字符,預計需要花費 8 分鐘才能閱讀完成。

這篇文章主要講解了“SQL server 有哪些分頁方法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學習“SQL server 有哪些分頁方法”吧!

這篇講的是 SQL server 的分頁方法,用的 SQL server 2012 版本。下面都用 pageIndex 表示頁數,pageSize 表示一頁包含的記錄。并且下面涉及到具體例子的,設定查詢第 2 頁,每頁含 10 條記錄。

首先說一下 SQL server 的分頁與 MySQL 的分頁的不同,mysql 的分頁直接是用 limit (pageIndex-1),pageSize 就可以完成,但是 SQL server 并沒有 limit 關鍵字,只有類似 limit 的 top 關鍵字。所以分頁起來比較麻煩。

??SQL server 分頁我所知道的就只有四種:三重循環;利用 max(主鍵); 利用 row_number 關鍵字,offset/fetch next 關鍵字(是通過搜集網上的其他人的方法總結的,應該目前只有這四種方法的思路,其他方法都是基于此變形的)。

要查詢的學生表的部分記錄

方法一:三重循環思路

??先取前 20 頁,然后倒序,取倒序后前 10 條記錄,這樣就能得到分頁所需要的數據,不過順序反了,之后可以將再倒序回來,也可以不再排序了,直接交給前端排序。

??還有一種方法也算是屬于這種類型的,這里就不放代碼出來了,只講一下思路,就是先查詢出前 10 條記錄,然后用 not in 排除了這 10 條,再查詢。

代碼實現

--  設置執行時間開始,用來查看性能的
set statistics time on ;
--  分頁查詢(通用型)select * 
from (select top pageSize * 
from (select top (pageIndex*pageSize) * 
from student 
order by sNo asc ) --  其中里面這層,必須指定按照升序排序,省略的話,查詢出的結果是錯誤的。as temp_sum_student 
order by sNo desc ) temp_order
order by sNo asc
--  分頁查詢第 2 頁,每頁有 10 條記錄
select * 
from (select top 10 * 
from (select top 20 * 
from student 
order by sNo asc ) --  其中里面這層,必須指定按照升序排序,省略的話,查詢出的結果是錯誤的。as temp_sum_student 
order by sNo desc ) temp_order
order by sNo asc
;

查詢出的結果及時間

方法二:利用 max(主鍵)

??先 top 前 11 條行記錄,然后利用 max(id)得到最大的 id,之后再重新再這個表查詢前 10 條,不過要加上條件,where id max(id)。

代碼實現

set statistics time on;
--  分頁查詢(通用型)select top pageSize * 
from student 
where sNo =
(select max(sNo) 
from (select top ((pageIndex-1)*pageSize+1) sNo
from student 
order by sNo asc) temp_max_ids) 
order by sNo;

order by sNo asc) temp_max_ids)  order by sNo;

查詢出的結果及時間

方法三:利用 row_number 關鍵字

??直接利用 row_number() over(order by id) 函數計算出行數,選定相應行數返回即可,不過該關鍵字只有在 SQL server 2005 版本以上才有。

SQL 實現

set statistics time on;
--  分頁查詢(通用型)select top pageSize * 
from (select row_number() 
over(order by sno asc) as rownumber,* 
from student) temp_row
where rownumber ((pageIndex-1)*pageSize);
set statistics time on;
--  分頁查詢第 2 頁,每頁有 10 條記錄
select top 10 * 
from (select row_number() 
over(order by sno asc) as rownumber,* 
from student) temp_row
where rownumber

查詢出的結果及時間

第四種方法:offset /fetch next(2012 版本及以上才有)代碼實現

set statistics time on;
--  分頁查詢(通用型)select * from student
order by sno 
offset ((@pageIndex-1)*@pageSize) rows
fetch next @pageSize rows only;
--  分頁查詢第 2 頁,每頁有 10 條記錄
select * from student
order by sno 
offset 10 rows
fetch next 10 rows only ;

offset A rows , 將前 A 條記錄舍去,fetch next B rows only,向后在讀取 B 條數據。

結果及運行時間

封裝的存儲過程

最后,我封裝了一個分頁的存儲過程,方便大家調用,這樣到時候寫分頁的時候,直接調用這個存儲過程就可以了。

分頁的存儲過程

create procedure paging_procedure
( @pageIndex int, --  第幾頁
 @pageSize int --  每頁包含的記錄數
begin 
 select top (select @pageSize) * --  這里注意一下,不能直接把變量放在這里,要用 select
 from (select row_number() over(order by sno) as rownumber,* 
 from student) temp_row 
 where rownumber (@pageIndex-1)*@pageSize;
--  到時候直接調用就可以了,執行如下的語句進行調用分頁的存儲過程
exec paging_procedure @pageIndex=2,@pageSize=10;

總結

??根據以上四種分頁的方法執行的時間可以知道,以上四種分頁方法中,第二,第三,第三四種方法性能是差不多的,但是第一種性能很差,不推薦使用。還有就是這篇博客這是測試了小量數據,還沒有分頁大量數據,所以不清楚在大量數據要分頁時哪種方法的性能更加好。我這里推薦第四種,畢竟第四種是 SQL server 公司升級后推出的新方法,所以應該理論上性能和可讀性都會更加好。

感謝各位的閱讀,以上就是“SQL server 有哪些分頁方法”的內容了,經過本文的學習后,相信大家對 SQL server 有哪些分頁方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關知識點的文章,歡迎關注!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-08-03發表,共計2959字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 潼南县| 巩留县| 永新县| 伊春市| 耒阳市| 新丰县| 囊谦县| 翼城县| 新邵县| 萨嘎县| 奉贤区| 阿拉善盟| 赤水市| 翁源县| 宾阳县| 普兰县| 洞口县| 新建县| 海伦市| 东海县| 察隅县| 瓦房店市| 商都县| 镇雄县| 新泰市| 湖南省| 德阳市| 剑川县| 常州市| 西和县| 临潭县| 定兴县| 黔东| 大石桥市| 青浦区| 中阳县| 邵东县| 米脂县| 平潭县| 津南区| 新营市|