色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

SQL server分頁(yè)的四種方法思路詳解(最全面教程)

瀏覽:99日期:2023-03-06 14:25:57
目錄
  • 方法一:三重循環(huán) 思路
  • 方法二:利用max(主鍵)
  • 方法三:利用row_number關(guān)鍵字
  • 第四種方法:offset /fetch next(2012版本及以上才有)
  • 總結(jié)

  這篇博客講的是SQL server的分頁(yè)方法,用的SQL server 2012版本。下面都用pageIndex表示頁(yè)數(shù),pageSize表示一頁(yè)包含的記錄。并且下面涉及到具體例子的,設(shè)定查詢第2頁(yè),每頁(yè)含10條記錄。

  首先說一下SQL server的分頁(yè)與MySQL的分頁(yè)的不同,mysql的分頁(yè)直接是用limit (pageIndex-1),pageSize就可以完成,但是SQL server 并沒有l(wèi)imit關(guān)鍵字,只有類似limit的top關(guān)鍵字。所以分頁(yè)起來比較麻煩。

  SQL server分頁(yè)我所知道的就只有四種:三重循環(huán);利用max(主鍵);利用row_number關(guān)鍵字,offset/fetch next關(guān)鍵字(是通過搜集網(wǎng)上的其他人的方法總結(jié)的,應(yīng)該目前只有這四種方法的思路,其他方法都是基于此變形的)。

要查詢的學(xué)生表的部分記錄

方法一:三重循環(huán) 思路

  先取前20頁(yè),然后倒序,取倒序后前10條記錄,這樣就能得到分頁(yè)所需要的數(shù)據(jù),不過順序反了,之后可以將再倒序回來,也可以不再排序了,直接交給前端排序。

  還有一種方法也算是屬于這種類型的,這里就不放代碼出來了,只講一下思路,就是先查詢出前10條記錄,然后用not in排除了這10條,再查詢。

代碼實(shí)現(xiàn)

-- 設(shè)置執(zhí)行時(shí)間開始,用來查看性能的set statistics time on ;-- 分頁(yè)查詢(通用型)select * from (select top pageSize * from (select top (pageIndex*pageSize) * from student order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結(jié)果是錯(cuò)誤的。as temp_sum_student order by sNo desc ) temp_orderorder by sNo asc-- 分頁(yè)查詢第2頁(yè),每頁(yè)有10條記錄select * from (select top 10 * from (select top 20 * from student order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結(jié)果是錯(cuò)誤的。as temp_sum_student order by sNo desc ) temp_orderorder by sNo asc;

查詢出的結(jié)果及時(shí)間

方法二:利用max(主鍵)

  先top前11條行記錄,然后利用max(id)得到最大的id,之后再重新再這個(gè)表查詢前10條,不過要加上條件,where id>max(id)。

代碼實(shí)現(xiàn)

set statistics time on;-- 分頁(yè)查詢(通用型)select top pageSize * from student where sNo>=(select max(sNo) from (select top ((pageIndex-1)*pageSize+1) sNofrom student order by  sNo asc) temp_max_ids) order by sNo;-- 分頁(yè)查詢第2頁(yè),每頁(yè)有10條記錄select top 10 * from student where sNo>=(select max(sNo) from (select top 11 sNofrom student order by  sNo asc) temp_max_ids) order by sNo;

查詢出的結(jié)果及時(shí)間

方法三:利用row_number關(guān)鍵字

  直接利用row_number() over(order by id)函數(shù)計(jì)算出行數(shù),選定相應(yīng)行數(shù)返回即可,不過該關(guān)鍵字只有在SQL server 2005版本以上才有。

SQL實(shí)現(xiàn)

set statistics time on;-- 分頁(yè)查詢(通用型)select top pageSize * from (select row_number() over(order by sno asc) as rownumber,* from student) temp_rowwhere rownumber>((pageIndex-1)*pageSize);set statistics time on;-- 分頁(yè)查詢第2頁(yè),每頁(yè)有10條記錄select top 10 * from (select row_number() over(order by sno asc) as rownumber,* from student) temp_rowwhere rownumber>10;

查詢出的結(jié)果及時(shí)間

第四種方法:offset /fetch next(2012版本及以上才有)

代碼實(shí)現(xiàn)

set statistics time on;-- 分頁(yè)查詢(通用型)select * from studentorder by sno offset ((@pageIndex-1)*@pageSize) rowsfetch next @pageSize rows only;-- 分頁(yè)查詢第2頁(yè),每頁(yè)有10條記錄select * from studentorder by sno  offset 10 rowsfetch next 10 rows only ;

offset A rows ,將前A條記錄舍去,fetch next B rows only ,向后在讀取B條數(shù)據(jù)。

結(jié)果及運(yùn)行時(shí)間

封裝的存儲(chǔ)過程

最后,我封裝了一個(gè)分頁(yè)的存儲(chǔ)過程,方便大家調(diào)用,這樣到時(shí)候?qū)懛猪?yè)的時(shí)候,直接調(diào)用這個(gè)存儲(chǔ)過程就可以了。

分頁(yè)的存儲(chǔ)過程

create procedure paging_procedure(	@pageIndex int, -- 第幾頁(yè)	@pageSize int  -- 每頁(yè)包含的記錄數(shù))asbegin 	select top (select @pageSize) *     -- 這里注意一下,不能直接把變量放在這里,要用select	from (select row_number() over(order by sno) as rownumber,* 			from student) temp_row 	where rownumber>(@pageIndex-1)*@pageSize;end-- 到時(shí)候直接調(diào)用就可以了,執(zhí)行如下的語(yǔ)句進(jìn)行調(diào)用分頁(yè)的存儲(chǔ)過程exec paging_procedure @pageIndex=2,@pageSize=10;

總結(jié)

  根據(jù)以上四種分頁(yè)的方法執(zhí)行的時(shí)間可以知道,以上四種分頁(yè)方法中,第二,第三,第三四種方法性能是差不多的,但是第一種性能很差,不推薦使用。還有就是這篇博客這是測(cè)試了小量數(shù)據(jù),還沒有分頁(yè)大量數(shù)據(jù),所以不清楚在大量數(shù)據(jù)要分頁(yè)時(shí)哪種方法的性能更加好。我這里推薦第四種,畢竟第四種是SQL server公司升級(jí)后推出的新方法,所以應(yīng)該理論上性能和可讀性都會(huì)更加好。

到此這篇關(guān)于SQL server分頁(yè)的四種方法的文章就介紹到這了,更多相關(guān)SQL server分頁(yè)內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MsSQL
主站蜘蛛池模板: 欧美一二三区在线 | a黄网站| 天堂一区二区三区在线观看 | a大片久久爱一级 | 欧美日韩一区二区三区免费不卡 | 400部大量精品情侣网站 | 亚洲欧美日韩久久一区 | 国产网曝手机视频在线观看 | 99久久精品免费看国产高清 | 日韩a级毛片免费视频 | 免费一级毛片免费播放 | 波多野结衣在线观看免费区 | 国产激情一级毛片久久久 | 九九国产精品九九 | a级精品九九九大片免费看 a级毛片免费观看网站 | 成人亚洲在线观看 | 日日摸人人拍人人澡 | 亚洲www在线 | 亚洲在线视频播放 | 成人小视频在线观看免费 | 国产精品国产亚洲精品看不卡 | 久久久久国产精品免费看 | 亚洲精品播放 | 成人午夜在线观看国产 | xx另类性欧美 | 亚洲日本综合 | 亚洲精品国产一区二区在线 | 综合色久七七综合七七蜜芽 | 国内精品免费一区二区三区 | 青青热在线精品视频免费 | 国内自拍第1页 | 国内自产拍自a免费毛片 | 国产日本韩国不卡在线视频 | 亚洲精品一区二区三区在线播放 | 欧美99| 99这里只有精品66视频 | 男女男在线精品网站免费观看 | 亚州视频一区二区 | 日本亚洲欧美国产日韩ay高清 | 欧美一区永久视频免费观看 | 亚州在线视频 |