麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > SQL Server > 正文

SQL分頁查詢方式匯總

2024-08-31 01:04:15
字體:
來源:轉載
供稿:網友

需求:查詢表dbo.Message,每頁10條,查詢第2頁

1:TOP()

SELECT TOP(20) * FROM dbo.Message WHERE Code NOT IN(SELECT TOP(10) Code FROM dbo.Message)

2:BETWEEN * AND * , Row_Number() OVER(ORDER BY *) AS rowNum

SELECT *,ROW_NUMBER() OVER(ORDER BY Code) AS rowNum INTO #a FROM dbo.Message SELECT * FROM #a WHERE rowNum BETWEEN 11 AND 20DROP TABLE #a;

3:WITH * AS () , Row_Number() OVER(ORDER BY *) AS rowNum

WITH sss AS(SELECT *,ROW_NUMBER() OVER(ORDER BY CreateTime) AS rowNum FROM DBO.Message)SELECT * FROM sss WHERE rowNum BETWEEN 11 AND 20

4: SQL Server 2012的OFFSET-FETCH篩選

SELECT * FROM DBO.Message ORDER BY CreateTime OFFSET 10 ROWS FETCH NEXT 10 ROWS ONLY

這里第4中方法做詳細介紹:

TOP選項是一個非常實用的篩選類型,但它有兩個缺陷——不是標準SQL,且不支持跳過功能。標準SQL定義的TOP類似篩選稱為OFFSET-FETCH,支持跳過功能,這對針對特定頁面的查詢非常有用。SQL Server2012引入了對OFFSET-FETCH篩選的支持。

SQL Server 2012中的OFFSET-FETCH篩選被視為ORDER BY子句的一部分,通常用于實現按順序顯示效果。OFFSET子句指定要跳過的行數,FETCH子句指定在跳過的行數后要篩選的行數。請思考一下下面的查詢示例。

SELECT orderid, orderdate, custid, empidFROM Sales.OrdersORDER BY orderdate, orderidOFFSET 50 ROWS FETCH NEXT 25 ROWS ONLY;

此查詢按orderdate、orderid順序(訂單日期從最遠到最近,并添加了決勝屬性(tiebreaker)orderid)排序Orders表中的行。基于此順序,OFFSET子句跳過前50行,由FETCH子句僅篩選下面的25行。

請注意,使用OFFSET-FETCH的查詢必須具有ORDER BY子句。此外,FETCH子句不支持沒有OFFSET子句。如果你不想跳過任何行,但是希望使用FETCH篩選,你應當使用OFFSET 0 ROWS來表示。不過,沒有FETCH的OFFSET是允許的,這種情況是跳過指定的行數,并返回查詢結果中所有剩余行。

OFFSET-FETCH語法有一些有趣的語言方面需要注意。單數格式ROW和復數格式ROWS是可以互換的,此舉是讓你能夠以直觀的類似英語方式來描述篩選。例如,假設你僅希望獲取一行,如果你指定了FETCH 1 ROWS,雖然這在語法上是有效的,不過看上去會很怪。因此,你可以使用FETCH 1 ROW格式。此互換同樣適用于OFFSET子句。另外,如果你不希望跳過任何行(OFFSET 0 ROWS),你可能覺得“first”比“next”更合適,因此,FIRST 和NEXT格式是可以互換的。

如你所見,從支持跳過功能看,OFFSET-FETCH子句比TOP子句更靈活。不過,OFFSET-FETCH 不支持PERCENT和WITH TIES選項,而TOP支持。由于OFFSET-FETCH是標準的,而TOP不是,我建議使用OFFSET-FETCH作為你的默認選擇,除非你需要TOP支持且OFFSET-FETCH不支持的功能。

以上所述是小編給大家介紹的SQL分頁查詢方式匯總,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!


注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 一级一级一级一级毛片 | 欧美一区成人 | 亚洲一级片在线观看 | 在线视频 亚洲 | 在线亚洲播放 | 国产成年人网站 | 色玖玖综合 | 久久久www成人免费精品 | 一区二区国产在线 | 全黄裸片武则天一级第4季 偿还电影免费看 | 亚洲国产一区二区三区 | 国产精品一区二区日韩 | 久久人 | 午夜啪视频| 2017亚洲男人天堂 | omofun 动漫在线观看 | 欧美一级毛片特黄黄 | 国产精品久久久久久久久久10秀 | 三级国产三级在线 | 欧洲成人综合网 | 蜜桃视频在线观看视频 | 久久久免费电影 | 在线看一区二区三区 | 久久艳片| 欧美日韩免费一区二区三区 | 羞羞的动漫在线观看 | 91九色精品国产 | 成人羞羞视频在线观看免费 | 91精品国产777在线观看 | 免费福利在线视频 | 欧美高清第一页 | 九九视频久久 | 欧美另类在线视频 | 国产成人综合在线观看 | 一区二区三区视频在线观看 | 久久人人爽人人爽人人片av高清 | av免费入口| 91九色蝌蚪国产 | 久久免费激情视频 | 国产日韩在线观看一区 | 99精彩视频在线观看 |