一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - SQL server分頁的4種方法示例(很全面)

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

2021-01-25 20:18KANLON Sql Server

這篇文章主要給大家介紹了關于SQL server分頁的4種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

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

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

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

要查詢的學生表的部分記錄

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

方法一:三重循環 思路

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

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

代碼實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
-- 設置執行時間開始,用來查看性能的
set statistics time on ;
-- 分頁查詢(通用型)
select *
from (select top pageSize *
from (select top (pageIndex*pageSize) *
from student
order by sNo asc ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結果是錯誤的。
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 ) -- 其中里面這層,必須指定按照升序排序,省略的話,查詢出的結果是錯誤的。
as temp_sum_student
order by sNo desc ) temp_order
order by sNo asc
;

查詢出的結果及時間

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

方法二:利用max(主鍵)

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

代碼實現

?
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;
-- 分頁查詢(通用型)
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;

查詢出的結果及時間

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

方法三:利用row_number關鍵字

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

SQL實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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;

查詢出的結果及時間

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

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

代碼實現

?
1
2
3
4
5
6
7
8
9
10
11
12
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條數據。

結果及運行時間

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

封裝的存儲過程

最后,我封裝了一個分頁的存儲過程,方便大家調用,這樣到時候寫分頁的時候,直接調用這個存儲過程就可以了。

分頁的存儲過程

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

總結

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

到此這篇關于SQL server分頁的4種方法的文章就介紹到這了,更多相關SQL server分頁方法內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲AV 日韩 国产 有码 | 99久久精品99999久久 | 天堂网在线.www天堂在线资源 | 亚洲六月丁香六月婷婷蜜芽 | 青草青青在线视频 | 国产一区二区在线观看美女 | 久久婷婷五月免费综合色啪 | 隔壁老王国产精品福利 | 激情偷拍网 | 国内精品伊人久久大香线焦 | 精品视频久久久久 | 99久久精品国产一区二区 | 免费高清在线 | 午夜亚洲精品久久久久久 | 男男双性生子产乳高辣h | 免费看一级 | 色婷综合 | 高清毛片一区二区三区 | 四虎在线精品观看免费 | 亚洲好视频 | 深夜免费网站 | 久久中文骚妇内射 | 亚洲福利一区 | 国产最新进精品视频 | 午夜久久久久久网站 | 免费一级特黄特色大片∵黄 | 男生的j桶女人屁免费视频 男生操男生 | 男人看片网址 | 亚洲国产成人久久综合一区77 | 免费一级毛片完整版在线看 | 欧美疯狂做爰3xxx | 国产98在线 | 日韩精品特黄毛片免费看 | 亚洲国产精品自在在线观看 | 午夜伦午夜伦锂电影 | 久久人妻少妇嫩草AV无码 | 久草在在线免视频在线观看 | 毛片免费全部免费观看 | 999久久久免费精品国产牛牛 | 美女脱了内裤让男桶爽 | 99免费精品 |