麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數(shù)據(jù)庫(kù) > SQL Server > 正文

SQL數(shù)據(jù)分頁查詢的方法

2024-08-31 01:04:18
字體:
供稿:網(wǎng)友

最近學(xué)習(xí)了一下SQL的分頁查詢,總結(jié)了以下幾種方法。

首先建立了一個(gè)表,隨意插入的一些測(cè)試數(shù)據(jù),表結(jié)構(gòu)和數(shù)據(jù)如下圖:

SQL數(shù)據(jù)分頁查詢,SQL數(shù)據(jù)查詢,SQL分頁查詢,SQL查詢

現(xiàn)在假設(shè)我們要做的是每頁5條數(shù)據(jù),而現(xiàn)在我們要取第三頁的數(shù)據(jù)。(數(shù)據(jù)太少,就每頁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]

結(jié)果:

SQL數(shù)據(jù)分頁查詢,SQL數(shù)據(jù)查詢,SQL分頁查詢,SQL查詢

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

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

方法二:

 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é)果:

SQL數(shù)據(jù)分頁查詢,SQL數(shù)據(jù)查詢,SQL分頁查詢,SQL查詢

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

缺點(diǎn)是性能比較差,和方法一大同小異。

方法三:

 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é)果:

SQL數(shù)據(jù)分頁查詢,SQL數(shù)據(jù)查詢,SQL分頁查詢,SQL查詢

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

方法四:

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

結(jié)果:

SQL數(shù)據(jù)分頁查詢,SQL數(shù)據(jù)查詢,SQL分頁查詢,SQL查詢

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

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

個(gè)人感覺這個(gè)方法比使用 ROW_NUMBER() 函數(shù)的方法要好(從代碼方面來看,代碼也少很多),至于性能方面沒有做過測(cè)試,就不說了。

不過,最后兩種方法的性能肯定是遠(yuǎn)超前面兩種方法的,具體的還是看實(shí)用。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MSSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产精品午夜未成人免费观看 | 国产精品免费成人 | 一级大片久久 | 免费观看一区二区三区视频 | 国产一级免费片 | 毛片在线免费 | 亚洲免费资源 | 久久人人人 | 性欧美极品xxxx欧美一区二区 | 亚洲第一成人在线 | 中国女人内谢69xxxx天美 | 久久草在线观看视频 | 亚洲成人福利在线 | 色婷婷久久一区二区 | 久久国产成人午夜av浪潮 | 黄色免费电影网址 | 天天曰夜夜操 | 毛片电影在线看 | 18欧美性xxxx极品hd | 黄色片免费看看 | 影视免费观看 | 91福利社在线 | 国产日产精品一区二区三区四区 | 欧产日产国产精品v | 日本精品免费观看 | 国产69精品久久久久9999不卡免费 | 免费性爱视频 | 毛片一级片 | 欧美中文字幕一区二区三区亚洲 | 久久老司机精品视频 | 在线成人免费视频 | 国产精品久久久久久久不卡 | 狠狠干五月天 | 黄色毛片观看 | 国产一区二区精品在线观看 | 国产1区2区3区中文字幕 | 哪里可以看免费的av | 国产精品性夜天天视频 | 91 在线视频观看 | 99亚洲精品 | 全免费午夜一级毛片真人 |