目錄
方法一:三重循環
思路
程式碼實作
查詢出的結果及時間
方法二:利用max (主鍵)
方法三:利用row_number關鍵字
SQL實作
第四種方法: offset /fetch next(2012版本以上才有)
結果及運行時間
#封裝的預存程序
總結
首頁 資料庫 SQL SQL server分頁方法有哪些

SQL server分頁方法有哪些

Aug 06, 2021 am 09:22 AM

這篇講的是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分頁方法有哪些

方法一:三重循環

思路

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

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

程式碼實作

-- 设置执行时间开始,用来查看性能的
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分頁方法有哪些

SQL server分頁方法有哪些

方法二:利用max (主鍵)

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

程式碼實作

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分頁方法有哪些

SQL server分頁方法有哪些

方法三:利用row_number關鍵字

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

SQL實作

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分頁方法有哪些

SQL server分頁方法有哪些

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

程式碼實作

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分頁方法有哪些

SQL server分頁方法有哪些

#封裝的預存程序

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

分頁的預存程序

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公司升級後推出的新方法,所以應該理論上效能和可讀性都會更加好。

相關推薦:《mysql教學

###

以上是SQL server分頁方法有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用SQL遵守數據隱私法規(GDPR,CCPA)? 如何使用SQL遵守數據隱私法規(GDPR,CCPA)? Mar 18, 2025 am 11:22 AM

文章討論了用於GDPR和CCPA合規性的SQL,專注於數據匿名,訪問請求和自動刪除過時的數據。(159個字符)

如何將SQL數據庫確保不受SQL注入等常見漏洞? 如何將SQL數據庫確保不受SQL注入等常見漏洞? Mar 18, 2025 am 11:18 AM

本文討論了針對SQL數據庫確保SQL數據庫,例如SQL注入,強調準備好的語句,輸入驗證和常規更新。

如何在SQL中實現數據分區以獲得性能和可伸縮性? 如何在SQL中實現數據分區以獲得性能和可伸縮性? Mar 18, 2025 am 11:14 AM

文章討論在SQL中實施數據分區,以提高性能和可伸縮性,詳細的方法,最佳實踐和監視工具。

sql datetime怎麼用 sql datetime怎麼用 Apr 09, 2025 pm 06:09 PM

DATETIME 數據類型用於存儲高精度的日期和時間信息,範圍為 0001-01-01 00:00:00 至 9999-12-31 23:59:59.9999999,語法為 DATETIME(precision),其中 precision 指定小數點後精度 (0-7),默認為 3。它支持排序、計算和時區轉換功能,但需要注意精度、範圍和時區轉換時的潛在問題。

如何將SQL用於數據倉庫和商業智能? 如何將SQL用於數據倉庫和商業智能? Mar 18, 2025 am 11:16 AM

本文討論了使用SQL用於數據倉庫和商業智能,重點關注ETL流程,數據建模和查詢優化。它還涵蓋BI報告創建和工具集成。

sql if語句怎麼用 sql if語句怎麼用 Apr 09, 2025 pm 06:12 PM

SQL IF 語句用於有條件地執行 SQL 語句,語法為: IF (condition) THEN {語句} ELSE {語句} END IF;。條件可以是任何有效的 SQL 表達式,如果條件為真,執行 THEN 子句;如果條件為假,執行 ELSE 子句。 IF 語句可以嵌套,允許更複雜的條件檢查。

sql server怎麼用sql語句創建表 sql server怎麼用sql語句創建表 Apr 09, 2025 pm 03:48 PM

在 SQL Server 中使用 SQL 語句創建表的方法:打開 SQL Server Management Studio 並連接到數據庫服務器。選擇要創建表的數據庫。輸入 CREATE TABLE 語句,指定表名、列名、數據類型和約束。單擊執行按鈕創建表。

如何在SQL中使用存儲過程和功能? 如何在SQL中使用存儲過程和功能? Mar 18, 2025 am 11:09 AM

文章討論了SQL中存儲程序和功能的使用和好處,包括性能優化及其之間的差異。

See all articles