亚洲女同成aV人片在线观看|亚洲www啪成人一区二区麻豆|亚洲国产中日韩精品综合|亚洲国产成人精品一级片|亚洲无码在线视频免费

歡迎來(lái)到 天津九安特機電工程有限公司
全國咨詢(xún)熱線(xiàn): 14982361834
聯(lián)系我們

地址:上海市寶山66號

電話(huà):18090326145

傳真:19913167781

郵箱:[email protected]

新聞中心
SQL server分頁(yè)的4種方法示例 很全面
  來(lái)源:天津九安特機電工程有限公司  更新時(shí)間:2026-05-05 00:41:00

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

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

首先說(shuō)一下SQL serv??er的種方分頁(yè)與MySQL的分頁(yè)的不同,mysql的例全分頁(yè)直接是用limi??t(′▽?zhuān)?) (pageIndex-1),pageSize就可以完成(╯°□°)╯︵ ┻━┻,但是分法示SQL server 并沒(méi)有limit關(guān)鍵字,只有類(lèi)似limit的種方top關(guān)鍵字。所以分頁(yè)起來(lái)比??較麻煩。例全

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

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

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

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

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

代碼實(shí)現

-- 設置執行時(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)出的結果是錯誤的。
as temp_sum_student
order by sNo desc ) temp_order
orde(′ω`)r by sNo asc

--(′_`) 分頁(yè)查詢(xún)第2頁(yè),每(′▽?zhuān)?頁(yè)有10條記錄
select *
from (select top 10 *
from (select top 20?? *
from student
order by sNo asc ) -- 其中里面這層,必須(′_ゝ`)指定按照升序排序,省略的話(huà),查詢(xún)出的結果是錯誤的。
as temp_sum_stud(′▽?zhuān)?ent
order by sNo desc ) temp_order
order by sNo asc
;

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

方法二:利用max(主鍵)

代碼實(shí)現

set statistics time on;
-- 分頁(yè)查詢(xún)(通用型)
select top pa(′ω`)geSize *
from student
where sNo>=
(select max(sNo)
from (select top ((pageIndex-1)*pageSize+1) sNo
from studen??t
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)出的結果(°ロ°) !及時(shí)間

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

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

SQL實(shí)現

set statistics time on;
-- 分頁(yè)查詢(xún)(通用型)
select top pageSize *
from (select row_number()
over(order by sno asc) as rownumber,*
f(′ω`)rom student) temp_row
where rownumber&(′ω`*)gt;((pageIndex-1)*(?????)pageS??ize);

set statistics time on;
-- 分頁(yè)查詢(xún)第2頁(yè),每頁(yè)有10條記錄
select top 10 *
from (select row_number()
over(order by sno as(′?_?`)c) as rownumber,*
from student) temp_row
where rownumber>10;

查詢(xún)出的結果及時(shí)間ヽ(′▽?zhuān)?ノ

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

代碼實(shí)現

set statistics time on;
-- 分頁(yè)查詢(xún)(通用型)
select * from student
order by sno
offset ((@pageIndex-1)*@pageSize) rows
fetch next @page??Size rows only;

-- 分頁(yè)查詢(xún)第2頁(yè),每頁(yè)ヾ(^-^)ノ有10條記錄(′;ω;`)
select * from student
order by sno
offset 10 rows
fetc??h next 10 rows only ;

offset A rows ,將前A條記錄舍去,fetchヽ(′ー`)ノ next B rows only ,向后在讀取B條數據。

結果及運行時(shí)間

封裝的存儲過(guò)程

最后,我封裝了一個(gè)分頁(yè)的存儲過(guò)程,方便大家調用,這樣??到時(shí)候寫(xiě)分頁(yè)的時(shí)候,直接調用這個(gè)存儲過(guò)程就可以了。

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

crea(????)te procedure paging_procedure
( @pageIndex int, -- 第幾頁(yè)
@pageSize int -- 每頁(yè)包含的記錄數
)
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í)候直接調(╬?益?)用(yong)就可以了,執行如下的語(yǔ)句進(jìn)行調用分頁(yè)的存儲過(guò)程
exec paging_procedure @pageIndex???=2,@??pageSize(′;ω;`)=(′?`)10;

總結

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

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

來(lái)源:腳本之家

鏈接:h( ?° ?? ?°)ttps://www.jb51.net/article/200647.htm

?
城市分站
友情鏈接
聯(lián)系我們

地址:上海市徐匯區66號

電話(huà):17301466985

傳真:15397061867

郵箱:[email protected]

1.1111

Copyright © 2026 Powered by 天津九安特機電工程有限公司   sitemap
亚洲女同成aV人片在线观看|亚洲www啪成人一区二区麻豆|亚洲国产中日韩精品综合|亚洲国产成人精品一级片|亚洲无码在线视频免费 福泉市| 新沂市| 田东县| 荥阳市| 馆陶县| 岳池县| 沁阳市| 凌源市| 吉木乃县| 永登县| 香河县| 乐至县| 张北县| 炎陵县| 河津市| 金乡县| 香河县| 江西省| 黑水县| 临夏市| 松原市| 江陵县| 宜州市| 井研县| 宣汉县| 五指山市| 博湖县| 塘沽区| 健康| 塘沽区| 刚察县| 武隆县| 自治县| 云安县| 田阳县| 长乐市| 图们市| 新竹县| 汝城县| 白山市| 庆城县| http://444 http://444 http://444 http://444 http://444 http://444