主頁(yè) > 知識(shí)庫(kù) > SQL數(shù)據(jù)分頁(yè)查詢的方法

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

熱門標(biāo)簽:電話機(jī)器人怎么代理商 家庭農(nóng)場(chǎng)地圖標(biāo)注名稱怎樣起名 電銷需要外呼系統(tǒng)嗎 互聯(lián)網(wǎng)電話外呼系統(tǒng) 零成本地圖標(biāo)注賺錢 我要地圖標(biāo)注數(shù)量有限制嗎 400電話辦理泰安 千呼電話機(jī)器人可以試用嗎 安卡拉地圖標(biāo)注app

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

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

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

此方法是先取出前10條的SID(前兩頁(yè)),排除前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é)果:

此方法是先取出前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é)果:

此方法的特點(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 Server 2008之后的版本(不含)。

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

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

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

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

您可能感興趣的文章:
  • 詳解SQLServer和Oracle的分頁(yè)查詢
  • 高效的SQLSERVER分頁(yè)查詢(推薦)
  • mysql分頁(yè)原理和高效率的mysql分頁(yè)查詢語(yǔ)句
  • oracle,mysql,SqlServer三種數(shù)據(jù)庫(kù)的分頁(yè)查詢的實(shí)例
  • Oracle實(shí)現(xiàn)分頁(yè)查詢的SQL語(yǔ)法匯總
  • 真正高效的SQLSERVER分頁(yè)查詢(多種方案)
  • SQL Server 分頁(yè)查詢存儲(chǔ)過(guò)程代碼
  • SQL行號(hào)排序和分頁(yè)(SQL查詢中插入行號(hào) 自定義分頁(yè)的另類實(shí)現(xiàn))
  • php下巧用select語(yǔ)句實(shí)現(xiàn)mysql分頁(yè)查詢
  • Mysql中分頁(yè)查詢的兩個(gè)解決方法比較

標(biāo)簽:池州 濱州 東營(yíng) 大同 新鄉(xiāng) 黃山 來(lái)賓 文山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL數(shù)據(jù)分頁(yè)查詢的方法》,本文關(guān)鍵詞  SQL,數(shù)據(jù),分頁(yè),查詢,的,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL數(shù)據(jù)分頁(yè)查詢的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于SQL數(shù)據(jù)分頁(yè)查詢的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章