欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

SQLserver有哪些分頁方法

這篇文章主要講解了“SQL server有哪些分頁方法”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“SQL server有哪些分頁方法”吧!

公司專注于為企業(yè)提供網(wǎng)站設(shè)計制作、做網(wǎng)站、微信公眾號開發(fā)、商城網(wǎng)站制作,微信小程序定制開發(fā),軟件按需規(guī)劃網(wǎng)站等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。憑借多年豐富的經(jīng)驗,我們會仔細(xì)了解各客戶的需求而做出多方面的分析、設(shè)計、整合,為客戶設(shè)計出具風(fēng)格及創(chuàng)意性的商業(yè)解決方案,創(chuàng)新互聯(lián)建站更提供一系列網(wǎng)站制作和網(wǎng)站推廣的服務(wù)。

這篇講的是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é)生表的部分記錄

SQL server有哪些分頁方法

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

思路

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

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

代碼實現(xiàn)
-- 設(shè)置執(zhí)行時間開始,用來查看性能的
set statistics time on ;
-- 分頁查詢(通用型)
select * 
from (select top pageSize * 
from (select top (pageIndex*pageSize) * 
from student 
order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結(jié)果是錯誤的。
as temp_sum_student 
order by sNo desc ) temp_order
order by sNo asc

-- 分頁查詢第2頁,每頁有10條記錄
select * 
from (select top 10 * 
from (select top 20 * 
from student 
order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結(jié)果是錯誤的。
as temp_sum_student 
order by sNo desc ) temp_order
order by sNo asc
;
查詢出的結(jié)果及時間

SQL server有哪些分頁方法

SQL server有哪些分頁方法

方法二:利用max(主鍵)

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

代碼實現(xiàn)
set statistics time on;
-- 分頁查詢(通用型)
select top pageSize * 
from student 
where sNo>=
(select max(sNo) 
from (select top ((pageIndex-1)*pageSize+1) sNo
from 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 sNo
from student 
order by  sNo asc) temp_max_ids) 
order by sNo;
查詢出的結(jié)果及時間

SQL server有哪些分頁方法

SQL server有哪些分頁方法

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

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

SQL實現(xiàn)
set statistics time on;
-- 分頁查詢(通用型)
select top pageSize * 
from (select row_number() 
over(order by sno asc) as rownumber,* 
from student) temp_row
where 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_row
where rownumber>10;
查詢出的結(jié)果及時間

SQL server有哪些分頁方法

SQL server有哪些分頁方法

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

代碼實現(xiàn)
set statistics time on;
-- 分頁查詢(通用型)
select * from student
order by sno 
offset ((@pageIndex-1)*@pageSize) rows
fetch next @pageSize rows only;

-- 分頁查詢第2頁,每頁有10條記錄
select * from student
order by sno  
offset 10 rows
fetch next 10 rows only ;

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

結(jié)果及運行時間

SQL server有哪些分頁方法

SQL server有哪些分頁方法

封裝的存儲過程

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

分頁的存儲過程

create procedure paging_procedure
(	@pageIndex int, -- 第幾頁
	@pageSize int  -- 每頁包含的記錄數(shù)
)
as
begin 
	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

-- 到時候直接調(diào)用就可以了,執(zhí)行如下的語句進行調(diào)用分頁的存儲過程
exec paging_procedure @pageIndex=2,@pageSize=10;

總結(jié)

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

感謝各位的閱讀,以上就是“SQL server有哪些分頁方法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對SQL server有哪些分頁方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

分享題目:SQLserver有哪些分頁方法
文章源于:http://aaarwkj.com/article24/igepje.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、全網(wǎng)營銷推廣App設(shè)計、建站公司、網(wǎng)站維護外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
国模在线视频一区二区| 欧美日韩一级一区二区三区| 91午夜福利视频在线观看| 一区二区三区毛片在线看| 亚洲精品午夜福利网| 2021最新四虎永久免费| 三级视频一区二区三区| 色偷偷91综合久久噜噜| 亚洲最新精品一区二区| 亚洲国产精品二区三区| 日本一道本不卡一区二区| 国产一区二区三区91精品| 日本成人精品二区在线观看| 在线播放亚洲一区二区三区| av丰满人妻一区二区| 亚洲无线码一区国产欧美国日| 亚洲欧美一区二区三区日本| 欧美精品日韩精品一区二区| 一区二区三区人妻系列| 亚洲精品乱码精品乱码不卡| 国语少妇高潮对白在线| 国产精品成人一区二区艾草| 国产精品中文字幕有码| 十八禁在线观看点击进入| 国产日韩欧美在线精品| 黄色午夜福利在线观看| 在线观看精品日本一区二| 日韩精品色av一区二区| 亚洲人成免费在线观看| 天天躁人人躁夜夜躁狠狠躁| 日韩成人在线高清视频| 日韩av天堂免费网站| 在线观看视频网站一卡二卡| 2020亚洲欧美日韩在线| 国产伦国产一区二区三区在线观看| 本色啪啪人妻夜嗨嗨av| 中文字幕乱码伊人三级| 国产精品一区波多野结衣| 高清亚洲一区二区三区| 国产欧美日韩经典一区| 亚洲欧美日韩在线观看a三区|