亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

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

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

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

 

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

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

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

代碼實現(xiàn)

-- 設置執(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é)果及時間

方法二:利用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é)果及時間

方法三:利用row_number關鍵字

直接利用 row_number() over(order by id) 函數(shù)計算出行數(shù),選定相應行數(shù)返回即可,不過該關鍵字只有在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é)果及時間

第四種方法: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é)果及運行時間

封裝的存儲過程

最后,我封裝了一個分頁的存儲過程,方便大家調(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公司升級后推出的新方法,所以應該理論上性能和可讀性都會更加好。

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

相關文章

  • SQL Server 樹形表非循環(huán)遞歸查詢的實例詳解

    SQL Server 樹形表非循環(huán)遞歸查詢的實例詳解

    這篇文章主要介紹了SQL Server 樹形表非循環(huán)遞歸查詢的實例詳解的相關資料,本文介紹的非常詳細具有參考借鑒價值,需要的朋友可以參考下
    2016-10-10
  • SQL Server下幾個危險的擴展存儲過程

    SQL Server下幾個危險的擴展存儲過程

    MSSQL數(shù)據(jù)庫存在幾個危險的擴展存儲過程,默認Public組可執(zhí)行權(quán)限,SQL注入者可利用此讀取文件目錄及用戶組,并可通過先寫入數(shù)據(jù)庫然后導出為文件的方法往服務器寫入危險腳本進一步提權(quán),或直接使用某些存儲過程執(zhí)行命令,如xp_cmdshell。
    2008-08-08
  • 數(shù)據(jù)庫常用的sql語句匯總

    數(shù)據(jù)庫常用的sql語句匯總

    這篇文章主要介紹了數(shù)據(jù)庫常用的sql語句匯總,需要的朋友可以參考下
    2020-02-02
  • SQL?DCL數(shù)據(jù)控制語言的使用

    SQL?DCL數(shù)據(jù)控制語言的使用

    本文主要介紹了SQL?DCL數(shù)據(jù)控制語言的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • SQL Server的鏈接服務器技術小結(jié)

    SQL Server的鏈接服務器技術小結(jié)

    這篇文章主要介紹了SQL Server的鏈接服務器技術的相關資料,需要的朋友可以參考下
    2014-07-07
  • 深入SQLServer中ISNULL與NULLIF的使用詳解

    深入SQLServer中ISNULL與NULLIF的使用詳解

    本篇文章是對SQLServer中ISNULL與NULLIF的使用進行了詳細分析介紹,需要的朋友參考下
    2013-06-06
  • sql 刷新視圖

    sql 刷新視圖

    視圖會保存元數(shù)據(jù),列,安全,以及依賴等信息,如果我們把基礎表的架構(gòu)更改了,并不會直接反映到視圖上來;更改架構(gòu)后,使用sp_refreshview存儲過程刷新視圖的元數(shù)據(jù)是一個好習慣;
    2009-07-07
  • SqlServer存儲過程實現(xiàn)及拼接sql的注意點

    SqlServer存儲過程實現(xiàn)及拼接sql的注意點

    這篇文章主要介紹了SqlServer存儲過程實現(xiàn)及拼接sql的注意點的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-07-07
  • SQL Server的死鎖說明

    SQL Server的死鎖說明

    死鎖是導致數(shù)據(jù)庫中的競爭性并發(fā)鎖,通常在多步驟事務中。當兩個或多個任務永久相互阻止時,每個任務都鎖定了其他任務嘗試鎖定的資源,就會發(fā)生死鎖。本文主要介紹了SQL Server的死鎖,感興趣的朋友可以參考閱讀
    2023-04-04
  • 在Ubuntu使用SQL?Server創(chuàng)建Go應用程序的圖文教程

    在Ubuntu使用SQL?Server創(chuàng)建Go應用程序的圖文教程

    這篇文章主要給大家介紹了關于在Ubuntu使用SQL?Server創(chuàng)建Go應用程序的相關資料,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2023-04-04

最新評論