網站首頁 編程語言 正文
SQLServer分頁方式
附帶50萬數據分頁時間[本機訪問|已重啟SQL服務|無其他程序干擾][非索引排序]
環境 WIN7 SQL服務12.04 SQL管理器SSMS14.01
1.Offset and Fetch 方式分頁
[SqlServer2012+] OFFSET 起始值 ROWS FETCH NEXT 每頁條數 ROWS ONLY
1.分頁條件不能重復,建議使用 分頁條件+主鍵 一起作為 分頁參數
2.分頁語句中 FIRST=NEXT ROWS=ROW
3.不使用排序可以用 order by (select 1)
使用 OFFSET FETCH 方式分頁必須帶order by key 其中key 必須是唯一值 不然會導致錯誤
select * from ( select * from sysrizhi ) table_temp order by riqi desc,sysrizhiid desc offset 10 rows fetch next 10 rows only
50萬行執行時間 770毫秒 索引排序10毫秒
select * from tcpliushui order by riqi OFFSET 100 ROWS FETCH NEXT 20 ROWS ONLY
2.row_number() 方式分頁
[SqlServer2005+] row_number()over(order by 已有排序字段)rownumber 然后根據rownumber篩選
使用方式
select * from (select *, ROW_NUMBER() Over( order by riqi desc,sysrizhiid desc ) as rowNum from ( select * from sysrizhi ) as table_1 ) as t where t.rowNum>10 and t.rowNum<=20
速度測試 50萬行執行時間 774毫秒 索引排序10毫秒
select * from (select row_number()over(order by riqi)rownumber,* from tcpliushui )a where rownumber>100 and rownumber<121
速度測試 50萬行執行時間 777毫秒 索引排序13毫秒
select top 20 * from (select row_number()over(order by riqi)rownumber,* from tcpliushui)a where rownumber>100
速度測試 50萬行執行時間 775毫秒 索引排序15毫秒
select * from (select row_number()over(order by riqi)rownumber,* from tcpliushui)a where rownumber between 101 and 120
3.row_number()變種
不基于已有字段 [SqlServer2005+]
速度測試 50萬行執行時間 779毫秒 索引排序15毫秒
select * from ( select row_number()over(order by tempColumn)rownumber,* from (select top 120 tempColumn=0,* from tcpliushui where 1=1 order by riqi)a )b where rownumber>100
4.not in/top方式分頁
速度測試 50萬行執行時間 858毫秒 索引排序51毫秒
select top 20 * from tcpliushui where tcpliushuiid not in (select top 100 tcpliushuiid from tcpliushui order by riqi) order by riqi
5.not exists方式分頁
速度測試 50萬行執行時間 852毫秒 索引排序22毫秒
select top 20 * from tcpliushui where not exists (select 1 from (select top 100 tcpliushuiid from tcpliushui order by riqi)a where a.tcpliushuiid=tcpliushui.tcpliushuiid) order by riqi
6.max/top方式分頁
速度測試 50萬行執行時間 819毫秒 索引排序12毫秒
select top 20 * from tcpliushui where tcpliushuiid>(select max(tcpliushuiid) from (select top 100 tcpliushuiid from tcpliushui order by riqi)a) order by riqi
原文鏈接:https://blog.csdn.net/u011363395/article/details/104414500
相關推薦
- 2023-01-17 Golang時間及時間戳的獲取轉換超全面詳細講解_Golang
- 2022-06-12 C語言全方位講解數組的使用_C 語言
- 2023-05-29 Python常見異常的處理方式淺析_python
- 2023-02-17 Python運算符優先級詳細整理_python
- 2022-05-18 C語言程序環境和預處理詳解分析_C 語言
- 2022-11-04 python使用tqdm模塊處理文件閱讀進度條顯示_python
- 2022-11-23 Shell執行腳本并輸出日志文件的方法_linux shell
- 2022-10-17 Kotlin編程基礎語法編碼規范_Golang
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支