程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> SQL數據分頁查詢的辦法

SQL數據分頁查詢的辦法

編輯:MSSQL

SQL數據分頁查詢的辦法。本站提示廣大學習愛好者:(SQL數據分頁查詢的辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是SQL數據分頁查詢的辦法正文


最近學習了一下SQL的分頁查詢,總結了以下幾種辦法。

首先樹立了一個表,隨意拔出的一些測試數據,表構造和數據如下圖:

如今假定我們要做的是每頁5條數據,而如今我們要取第三頁的數據。(數據太少,就每頁5條了)

辦法一:

 select top 5 * 
 from [StuDB].[dbo].[ScoreInfo] 
 where [SID] not in 
 (select top 10 [SID] 
 from [StuDB].[dbo].[ScoreInfo] 
 order by [SID])
 order by [SID]

後果:

此辦法是先取出前10條的SID(前兩頁),掃除前10條數據的SID,然後在剩下的數據外面取出前5條數據。

缺陷就是它會遍歷表中一切數據兩次,數據量大時功能不好。

辦法二:

 select top 5 * 
 from [StuDB].[dbo].[ScoreInfo] 
 where [SID]> 
 (select MAX(t.[SID]) from (select top 10 [SID] from [StuDB].[dbo].[ScoreInfo] order by [SID]) t )
 order by [SID]

後果:

此辦法是先取出前10條數據的SID,然後取出SID的最大值,再從數據外面取出 大於 前10條SID的最大值 的前5條數據。

缺陷是功能比擬差,和辦法一迥然不同。

辦法三:

 select * 
 from (select *,ROW_NUMBER() over(order by [SID]) ROW_ID from [StuDB].[dbo].[ScoreInfo]) t
 where t.[SID] between (5*(3-1)+1) and 5*3

後果:

此辦法的特點就是運用 ROW_NUMBER() 函數,這個辦法功能比前兩種辦法要好,只會遍歷一次一切的數據。適用於Sql Server 2000之後的版本(不含)。

辦法四:

 select * 
 from [StuDB].[dbo].[ScoreInfo]
 order by [SID] 
 offset 5*2 rows fetch next 5 rows only

後果:

此辦法適用於Sql Server 2008之後的版本(不含)。

offset 10 rows fetch next 5 rows only 這句代碼我的了解是:跳過後面10條數據(前2頁)從下一條開端取5條數據。

團體覺得這個辦法比運用 ROW_NUMBER() 函數的辦法要好(從代碼方面來看,代碼也少很多),至於功能方面沒有做過測試,就不說了。

不過,最後兩種辦法的功能一定是遠超後面兩種辦法的,詳細的還是看適用。

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支持。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved