国产探花免费观看_亚洲丰满少妇自慰呻吟_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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 枣阳市| 新丰县| 合川市| 拉萨市| 永善县| 玉田县| 雅安市| 靖边县| 海城市| 锡林郭勒盟| 高邑县| 康保县| 洛南县| 大化| 西畴县| 肇州县| 齐齐哈尔市| 宁德市| 昌都县| 溧阳市| 镇安县| 永清县| 手游| 淮安市| 泸州市| 江油市| 鄂州市| 齐河县| 阳原县| 乌恰县| 西盟| 衡水市| 张家口市| 沙湾县| 三明市| 贵港市| 开阳县| 伊宁县| 夏河县| 左贡县| 石门县|