溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Sqlserver使用ROW_NUMBER()函數(shù)進(jìn)行數(shù)據(jù)分頁(yè)

發(fā)布時(shí)間:2020-06-27 22:02:06 來(lái)源:網(wǎng)絡(luò) 閱讀:1204 作者:宇宙小元帥 欄目:關(guān)系型數(shù)據(jù)庫(kù)

在Sqlserver數(shù)據(jù)庫(kù)中,如果查詢表中含有自增長(zhǎng)Id列,一般會(huì)采用select Top的方式來(lái)數(shù)據(jù)的分頁(yè)操作。而實(shí)際上很多數(shù)據(jù)表設(shè)計(jì)的時(shí)候,不一定含有自增長(zhǎng)Id列,那么數(shù)據(jù)庫(kù)沒(méi)有Id自增列的時(shí)候要對(duì)數(shù)據(jù)分頁(yè)怎么辦呢,此時(shí)則需要使用ROW_NUMBER()函數(shù)來(lái)對(duì)數(shù)據(jù)分頁(yè),ROW_NUMBER()一般與OVER(order by)一起連用。
使用Row_Number來(lái)數(shù)據(jù)分頁(yè)的格式如下:
With tempTb AS
(
Select ROW_NUMBER() OVER(order by 排序的列 ASC) AS RowNumber, FROM 數(shù)據(jù)表_Table
)
Select
FROM tempTb Where RowNumber>開(kāi)始行號(hào) AND RowNumber<結(jié)束行號(hào);

舉個(gè)例子,我們要查詢Student表中的學(xué)生數(shù)據(jù),按學(xué)生出生日期從前到后排序,取出出生日期排在第31位到第60位的數(shù)據(jù),語(yǔ)句如下:
With tempTb AS
(
Select ROW_NUMBER() OVER(order by BirthDay ASC) AS RowNumber, FROM Student
)
Select
FROM tempTb Where RowNumber>30 AND RowNumber<=60

備注:此原創(chuàng)文章最早發(fā)表于博主個(gè)人站點(diǎn)IT技術(shù)小趣屋,原文鏈接Sqlserver使用ROW_NUMBER()函數(shù)進(jìn)行數(shù)據(jù)分頁(yè)_IT技術(shù)小趣屋,轉(zhuǎn)載請(qǐng)標(biāo)明出處。

博主個(gè)人技術(shù)交流群:960640092,博主微信公眾號(hào)如下:
Sqlserver使用ROW_NUMBER()函數(shù)進(jìn)行數(shù)據(jù)分頁(yè)

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI