91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL server有哪些分頁方法

發布時間:2021-08-06 09:50:01 來源:億速云 閱讀:266 作者:chen 欄目:數據庫

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

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

感謝各位的閱讀,以上就是“SQL server有哪些分頁方法”的內容了,經過本文的學習后,相信大家對SQL server有哪些分頁方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

sql
AI

泸定县| 怀宁县| 辛集市| 新巴尔虎左旗| 灯塔市| 铅山县| 岳池县| 连山| 灵武市| 遂昌县| 昔阳县| 大竹县| 新乡县| 武安市| 临泽县| 南乐县| 格尔木市| 枣庄市| 恭城| 克什克腾旗| 盐亭县| 高雄市| 海伦市| 合江县| 吉木乃县| 务川| 深州市| 松原市| 灌云县| 界首市| 昌江| 桂阳县| 泰宁县| 朝阳县| 邮箱| 克东县| 濉溪县| 麟游县| 临颍县| 泊头市| 红安县|