溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL中怎么實現(xiàn)數(shù)據(jù)分頁查詢操作

發(fā)布時間:2021-08-13 15:48:20 來源:億速云 閱讀:165 作者:Leah 欄目:數(shù)據(jù)庫

這篇文章給大家介紹SQL中怎么實現(xiàn)數(shù)據(jù)分頁查詢操作,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

方法一:

 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]

結(jié)果:

此方法是先取出前10條的SID(前兩頁),排除前10條數(shù)據(jù)的SID,然后在剩下的數(shù)據(jù)里面取出前5條數(shù)據(jù)。

缺點就是它會遍歷表中所有數(shù)據(jù)兩次,數(shù)據(jù)量大時性能不好。

方法二:

 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]

結(jié)果:

此方法是先取出前10條數(shù)據(jù)的SID,然后取出SID的最大值,再從數(shù)據(jù)里面取出 大于 前10條SID的最大值 的前5條數(shù)據(jù)。

缺點是性能比較差,和方法一大同小異。

方法三:

 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

結(jié)果:

此方法的特點就是使用 ROW_NUMBER() 函數(shù),這個方法性能比前兩種方法要好,只會遍歷一次所有的數(shù)據(jù)。適用于Sql Server 2000之后的版本(不含)。

方法四:

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

結(jié)果:

此方法適用于Sql Server 2008之后的版本(不含)。

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

關于SQL中怎么實現(xiàn)數(shù)據(jù)分頁查詢操作就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

sql
AI