久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

SQL中怎么實現數據分頁查詢操作

146次閱讀
沒有評論

共計 1047 個字符,預計需要花費 3 分鐘才能閱讀完成。

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

方法一:

 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 條數據。

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

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-08-01發表,共計1047字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 祁连县| 安西县| 义乌市| 桃园市| 石阡县| 江油市| 西乡县| 揭西县| 托克托县| 准格尔旗| 海城市| 普宁市| 安多县| 彭水| 黄平县| 麟游县| 峨眉山市| 宣武区| 若尔盖县| 郁南县| 多伦县| 舞阳县| 清水河县| 石河子市| 谢通门县| 南华县| 长治县| 新干县| 南雄市| 会东县| 平顶山市| 斗六市| 贵德县| 安福县| 寿宁县| 东丰县| 万源市| 绥德县| 郧西县| 文山县| 玉龙|