日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

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

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

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

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

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

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

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

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

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

-- 設(shè)置執(zhí)行時(shí)間開始,用來查看性能的set statistics time on ;-- 分頁查詢(通用型)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-- 分頁查詢第2頁,每頁有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;-- 分頁查詢(通用型)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;-- 分頁查詢第2頁,每頁有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;-- 分頁查詢(通用型)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;-- 分頁查詢第2頁,每頁有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;-- 分頁查詢(通用型)select * from studentorder by sno offset ((@pageIndex-1)*@pageSize) rowsfetch next @pageSize rows only;-- 分頁查詢第2頁,每頁有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í)間

封裝的存儲過程

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

分頁的存儲過程

create procedure paging_procedure(	@pageIndex int, -- 第幾頁	@pageSize int  -- 每頁包含的記錄數(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í)行如下的語句進(jìn)行調(diào)用分頁的存儲過程exec paging_procedure @pageIndex=2,@pageSize=10;

總結(jié)

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

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

標(biāo)簽: MsSQL
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美成a人片免费观看久久五月天| 久久精品国产www456c0m| 亚洲免费成人| 欧美福利在线| 国产主播一区| 久久久影院免费| 久久精品国产99久久| 精品国模一区二区三区| 韩国三级一区| 国产尤物精品| 自拍日韩欧美| 99精品综合| 国产91久久精品一区二区| 麻豆成人在线观看| 精品三级av在线导航| 亚洲永久av| 日韩av中文字幕一区二区三区| 91久久精品无嫩草影院| 国产毛片一区二区三区| 国产精品欧美三级在线观看 | 精品视频97| 日韩国产一区| 欧美特黄a级高清免费大片a级| 99香蕉国产精品偷在线观看 | 欧美精品国产| 蜜桃精品视频| 欧美日韩精品免费观看视完整 | 伊人久久在线| 免费不卡中文字幕在线| 视频一区中文字幕| 久久精品av麻豆的观看方式| 精品国产黄a∨片高清在线| 日韩不卡视频在线观看| 首页欧美精品中文字幕| 日本不卡高清| 成人在线视频免费看| 婷婷综合网站| 亚洲人成网77777色在线播放| 欧美日本二区| 九九精品调教| 亚洲日韩中文字幕一区| 日本黄色精品| 在线一区免费观看| 青青国产精品| 日韩视频网站在线观看| 亚洲一区二区三区久久久| 麻豆精品在线| 伊人久久亚洲影院| 国产精品主播在线观看| 日本精品不卡| 欧美亚洲自偷自偷| 蜜桃精品在线| 日本一区二区三区中文字幕| 国产suv精品一区二区四区视频| 91精品国产成人观看| 婷婷综合电影| 国产不卡人人| 日本一不卡视频| 欧美日韩国产v| 久久精品凹凸全集| 香蕉国产精品| 国产精品伦一区二区| 久久亚洲精品中文字幕蜜潮电影| 四虎在线精品| 国产成人精品一区二区三区免费 | 亚洲www免费| 日韩av中文字幕一区二区| 欧美日韩精品免费观看视完整 | 青青国产精品| 国户精品久久久久久久久久久不卡| 亚洲一区二区三区无吗| 成人精品动漫一区二区三区| 亚洲免费婷婷| 91tv亚洲精品香蕉国产一区| 国产免费久久| 首页亚洲欧美制服丝腿| 蜜桃av.网站在线观看| 日韩av一二三| 亚洲成人一区| 国产精选在线| 日本综合精品一区| 在线亚洲国产精品网站| 欧美成人精品三级网站| 美女视频黄久久| 日韩三级久久| 欧美成人国产| 国产一区二区三区四区五区| 日本成人手机在线| 99pao成人国产永久免费视频| 国产一区二区亚洲| 久久国产婷婷国产香蕉| 一区二区三区国产在线| 婷婷综合亚洲| 亚洲不卡av不卡一区二区| 激情不卡一区二区三区视频在线| 日韩激情精品| 亚洲一二av| 国产一区导航| 欧美日韩免费观看一区=区三区| 日韩成人a**站| 欧美日韩中出| 日韩一区精品| 一区二区三区国产在线| 亚洲精品va| 久久精品91| 日韩精品水蜜桃| 日韩视频网站在线观看| 亚洲综合电影| 久久久男人天堂| 一区二区精品伦理...| 精品亚洲成人| 精品视频免费| 国产精品二区不卡| 日产精品一区二区| www.九色在线| 精品视频亚洲| 精品视频亚洲| 国产欧美一区二区三区精品酒店| 色综合视频一区二区三区日韩 | 99久久99视频只有精品| 亚洲风情在线资源| 国产精品嫩模av在线| 久久精品xxxxx| 国产精品一区二区精品| 国产麻豆一区| 国产精品宾馆| 国产精品传媒麻豆hd| 麻豆一区二区99久久久久| 精品亚洲成人| 久久久久久色 | 国产探花在线精品一区二区| 日本免费一区二区视频| 亚洲精品第一| 天堂久久av| 日韩激情av在线| 日韩av不卡一区二区| 日韩不卡在线观看日韩不卡视频| 日本一区福利在线| 国产日韩欧美在线播放不卡| 国产精品一区二区三区www| 麻豆国产精品一区二区三区| 精品一区二区三区在线观看视频| 国产精品99一区二区三| 欧美中文一区二区| 亚洲欧美视频| 亚洲精品看片| 欧美另类中文字幕 | 精品视频自拍| 国产成人精品一区二区免费看京| 日韩电影免费网站| 亚洲电影在线一区二区三区| 亚洲欧美不卡| 久久国际精品| 国产成人精品一区二区三区视频 | 美女网站一区| 日韩精品一区第一页| 免费精品视频最新在线| 日韩在线麻豆| 免费视频一区二区三区在线观看| 中文字幕色婷婷在线视频| 九九久久婷婷| 日本成人一区二区| 欧美激情另类| 国产精品女主播一区二区三区| 亚洲精品日本| 国产一区国产二区国产三区| 亚洲大全视频| 欧美日一区二区三区在线观看国产免| 精品黄色一级片| 免费不卡中文字幕在线| 日韩激情精品| 国产精品99久久精品| 伊人久久婷婷| 国产精品久久| 欧美成人久久| 欧美日韩一区自拍| 亚洲成人二区| 91p九色成人| 色婷婷久久久| 日韩精品三级| 亚洲欧洲美洲av| 天堂va欧美ⅴa亚洲va一国产| 国产精品成人一区二区不卡| 亚洲欧美日韩综合国产aⅴ| 欧美激情日韩| 亚洲国产一区二区在线观看 | 国产精品www994| 九九久久电影| 久久av日韩| 国产亚洲精品v| 国产在视频一区二区三区吞精| 国产女优一区| 精品亚洲a∨| 亚洲精品观看| 日韩免费福利视频| 国产日本精品| 精品国模一区二区三区| 国产精品qvod| 三级欧美在线一区| 国产videos久久|