SQL數(shù)據(jù)分頁(yè)查詢的方法
最近學(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è))從下一條開始取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è)解決方法比較
相關(guān)文章
數(shù)據(jù)庫(kù)Left join , Right Join, Inner Join 的相關(guān)內(nèi)容,非常實(shí)用
Left join , Right Join, Inner Join 的相關(guān)內(nèi)容,非常實(shí)用2009-07-07SQL?Server下7種“數(shù)據(jù)分頁(yè)”方案全網(wǎng)最新最全
這篇文章主要介紹了SQL?Server下7種“數(shù)據(jù)分頁(yè)”方案,全網(wǎng)最全,本文下面重點(diǎn)闡述上述【第二種】方案在SQL?Server上的使用(其它種類數(shù)據(jù)庫(kù)由于Sql語(yǔ)句略有差異,所以需要調(diào)整,但方案也類似),需要的朋友可以參考下2023-01-01盤點(diǎn)SqlServer?分頁(yè)方式和拉姆達(dá)表達(dá)式分頁(yè)
這篇文章主要介紹了SqlServer?5種分頁(yè)方式和拉姆達(dá)表達(dá)式分頁(yè),進(jìn)來(lái)看看吧,本文結(jié)合示例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下2022-12-12sql2000掛起無(wú)法安裝的問(wèn)題的解決方法
關(guān)于:以前的某個(gè)程序安裝已在安裝計(jì)算機(jī)上創(chuàng)建掛起的文件操作 解決辦法2008-11-11解決無(wú)法在unicode和非unicode字符串?dāng)?shù)據(jù)類型之間轉(zhuǎn)換的方法詳解
本篇文章是對(duì)無(wú)法在unicode和非unicode字符串?dāng)?shù)據(jù)類型之間轉(zhuǎn)換的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06MS-SQL Server 2005 其中三個(gè)版本的比較
MS-SQL Server 2005 其中三個(gè)版本的比較...2006-12-12使用sqlserver官方驅(qū)動(dòng)包調(diào)用存儲(chǔ)過(guò)程遇到的坑及解決方法
這篇文章主要介紹了用sqlserver官方驅(qū)動(dòng)包調(diào)用存儲(chǔ)過(guò)程遇到的一個(gè)坑,解決方法大概就是換驅(qū)動(dòng)包,在在存儲(chǔ)過(guò)程首行添加 set nocount on ,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10SQLSERVER全文目錄全文索引的使用方法和區(qū)別講解
這篇文章主要介紹了SQLSERVER全文目錄全文索引的使用方法,有圖有代碼,大家參考使用吧2013-11-11