激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - Sql Server - SQL server分頁(yè)的4種方法示例(很全面)

SQL server分頁(yè)的4種方法示例(很全面)

2021-01-25 20:18KANLON Sql Server

這篇文章主要給大家介紹了關(guān)于SQL server分頁(yè)的4種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

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

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

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

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

SQL server分頁(yè)的4種方法示例(很全面)

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

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
-- 設(shè)置執(zhí)行時(shí)間開(kāi)始,用來(lái)查看性能的
set statistics time on ;
-- 分頁(yè)查詢(xún)(通用型)
select *
from (select top pageSize *
from (select top (pageIndex*pageSize) *
from student
order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話(huà),查詢(xún)出的結(jié)果是錯(cuò)誤的。
as temp_sum_student
order by sNo desc ) temp_order
order by sNo asc
 
-- 分頁(yè)查詢(xún)第2頁(yè),每頁(yè)有10條記錄
select *
from (select top 10 *
from (select top 20 *
from student
order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話(huà),查詢(xún)出的結(jié)果是錯(cuò)誤的。
as temp_sum_student
order by sNo desc ) temp_order
order by sNo asc
;

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

SQL server分頁(yè)的4種方法示例(很全面) SQL server分頁(yè)的4種方法示例(很全面)

方法二:利用max(主鍵)

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
set statistics time on;
-- 分頁(yè)查詢(xún)(通用型)
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;
 
 
-- 分頁(yè)查詢(xún)第2頁(yè),每頁(yè)有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;

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

SQL server分頁(yè)的4種方法示例(很全面) SQL server分頁(yè)的4種方法示例(很全面)

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
set statistics time on;
-- 分頁(yè)查詢(xún)(通用型)
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;
-- 分頁(yè)查詢(xún)第2頁(yè),每頁(yè)有10條記錄
select top 10 *
from (select row_number()
over(order by sno asc) as rownumber,*
from student) temp_row
where rownumber>10;

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

SQL server分頁(yè)的4種方法示例(很全面) SQL server分頁(yè)的4種方法示例(很全面)

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
set statistics time on;
-- 分頁(yè)查詢(xún)(通用型)
select * from student
order by sno
offset ((@pageIndex-1)*@pageSize) rows
fetch next @pageSize rows only;
 
-- 分頁(yè)查詢(xún)第2頁(yè),每頁(yè)有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é)果及運(yùn)行時(shí)間

SQL server分頁(yè)的4種方法示例(很全面) SQL server分頁(yè)的4種方法示例(很全面)

封裝的存儲(chǔ)過(guò)程

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
create procedure paging_procedure
(   @pageIndex int, -- 第幾頁(yè)
    @pageSize int -- 每頁(yè)包含的記錄數(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
 
-- 到時(shí)候直接調(diào)用就可以了,執(zhí)行如下的語(yǔ)句進(jìn)行調(diào)用分頁(yè)的存儲(chǔ)過(guò)程
exec paging_procedure @pageIndex=2,@pageSize=10;

總結(jié)

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

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

原文鏈接:https://www.cnblogs.com/kanlon2015/p/14039000.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久成人精品视频 | 青青草好吊色 | 久久国产精品久久精品国产演员表 | 精品xxxx户外露出视频 | 中文字幕在线免费观看电影 | 成人短视频在线播放 | 久久精品一区二区三区四区五区 | 国产在线播放91 | 欧美成人影院 | 成人欧美在线观看 | 高清在线观看av | 国产超碰人人做人人爱ⅴa 国产精品久久久久久久hd | 亚洲天堂成人在线观看 | 久久久中精品2020中文 | 黄色男女视频 | 欧美一级做一级爱a做片性 91在线视频观看 | 国产色视频一区 | 欧洲性xxxxx 亚洲第一精品在线 | 蜜桃视频最新网址 | 九九热在线免费观看视频 | 成码无人av片在线观看网站 | 免费啪视频在线观看 | 国产高清美女一级毛片久久 | 久久综合婷婷香五月 | 国产精品久久久久久久久久三级 | 久久欧美亚洲另类专区91大神 | 精品成人免费视频 | 色播视频在线播放 | 精国产品一区二区三区四季综 | 国产精品免费小视频 | 亚洲成年人免费网站 | 成人免费一区 | 国产高潮好爽受不了了夜色 | 在线观看免费视频麻豆 | 海角在线观看91一区二区 | 2023av在线视频 | 在线中文字幕播放 | 色人阁导航 | 久久久久97国产精 | 黄色一级片在线观看 | 久久久青 |