国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

SQL Server 分頁編號的另一種方式【推薦】

2024-08-31 01:05:23
字體:
來源:轉載
供稿:網友

今天看書講T-SQL,看到了UNBOUNDED PRECEDING,就想比對下ROW_NUMBER()的運行速度。

sql及相關的結果如下,數據庫中的數據有5W+。

ROW_NUMBER():SET STATISTICS TIME ONSELECT  ROW_NUMBER() OVER(ORDER BY Id DESC) rn,IdFROM  dbo.T_MyCourse

運行結果

SQLServer,分頁,編號

UNBOUNDED PRECEDINGSET STATISTICS TIME ONSELECT  SUM(1) OVER(ORDER BY Id DESC ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) rn,IdFROM  dbo.T_MyCourse

運行結果

SQLServer,分頁,編號

通過運行之后,看到結果,使用微軟官方提供的方法進行編號排序,速度明顯的提高。

不過我使用上述方法進行分頁獲取數據的時候結果又有點不一樣。

分頁獲取數據:

ROW_NUMBER() 分頁獲取數據:

SET STATISTICS TIME ONSELECT  *FROM  (  SELECT    ROW_NUMBER() OVER(ORDER BY Id DESC) rn,Id  FROM    dbo.T_MyCourse  )aWHERE  a.rn BETWEEN 55 AND 444

 SQLServer,分頁,編號

執行sql命令:DBCC DROPCLEANBUFFERS ,清除數據庫緩存后的結果

SQLServer,分頁,編號

UNBOUNDED分頁獲取數據:

SET STATISTICS TIME ONSELECT  *FROM  (  SELECT    SUM(1) OVER(ORDER BY Id DESC ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) rn,Id  FROM    dbo.T_MyCourse  )aWHERE  a.rn BETWEEN 22 AND 444

 SQLServer,分頁,編號

UNBOUNDED這個方式下執行了DBCC DROPCLEANBUFFERS 清除緩存的sql也沒有用,執行時間沒有變化。

 通過上述結果,看到ROW_NUMBER()獲取分頁的數據明顯更快,我猜測是微軟對ROW_NUMBER()這個方法做了優化,可能是有緩存,讀取的緩存中的數據然后進行分頁。

總結

以上所述是小編給大家介紹的SQL Server 分頁編號的另一種方式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宣恩县| 密云县| 随州市| 温州市| 桃源县| 中方县| 枣阳市| 黑河市| 盖州市| 罗山县| 江口县| 兴城市| 赣榆县| 固阳县| 秦皇岛市| 漳浦县| 怀远县| 建平县| 玛沁县| 平乐县| 龙江县| 张家口市| 三台县| 温州市| 通山县| 张家界市| 临清市| 墨脱县| 岢岚县| 浦江县| 万山特区| 舟曲县| 科技| 寻乌县| 寻甸| 友谊县| 马鞍山市| 青州市| 南溪县| 新竹县| 乾安县|