成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

盤點SqlServer 分頁方式和拉姆達表達式分頁

瀏覽:270日期:2023-03-06 14:25:58
目錄
  • 1、ROW_NUMBER() OVER()方式(SQL2012以下推薦使用)
  • 2、offset fetch next方式(SQL2012及以上的版本才支持:推薦使用 )
  • 3、top not in方式 (不推薦)
  • 4、通過升序與降序方式進行查詢分頁(不推薦)
  • 5、采用MAX(ID)或者MIN(ID)函數(不推薦)
  • 6、Lambda表達式分頁(推薦使用)

現在基本上大家都在使用各種輪子自帶的分頁,大家是否還記得sql分頁怎么寫?

今天我們就來盤一盤怎么寫和用哪種方式寫。

歡迎大家評論區討論。

1、ROW_NUMBER() OVER()方式(SQL2012以下推薦使用)

示例:

SELECT * FROM    (SELECT ROW_NUMBER() OVER(ORDER BY menuId) AS RowId,* FROM sys_menu ) AS r WHERE  RowId BETWEEN 1 AND 10

用子查詢新增一列行號(ROW_NUMBER)RowId查詢,比較高效的查詢方式,只有在SQL Server2005或更高版本才支持。

BETWEEN 1 AND 10 是指查詢第1到第10條數據(閉區間),在這里面需要注意的是OVER的括號里面可以寫多個排序字段。

查詢結果如下:

通用用法

--pageIndex 表示指定頁--pageSize  表示每頁顯示的條數SELECT * FROM    (SELECT ROW_NUMBER() OVER(ORDER BY 排序字段) AS RowId,* FROM 表名 ) AS r WHERE  RowId  BETWEEN ((pageIndex-1)*pageSize + 1) AND (pageIndex * PageSize)

2、offset fetch next方式(SQL2012及以上的版本才支持:推薦使用 )

示例:

--offset fetch next方式查詢,最高效的查詢方式,只有在SQL Server2012或更高版本才支持SELECT * FROM sys_menu ORDER BY menuId offset 0 ROWS FETCH NEXT 10 ROWS ONLY

offset 是跳過多少行,

next是取接下來的多少行,

句式 offset...rows fetch nect ..rows only ,注意rows和末尾的only 不要寫漏掉了,并且這種方式必須要接著Order by XX 使用,不然會報錯。

查詢結果如下:

通用用法

--pageIndex 表示指定頁--pageSize  表示每頁顯示的條數SELECT * FROM 表名 ORDER BY 排序字段 offset ((pageIndex - 1) * pageSize) ROWS FETCH NEXT pageSize ROWS ONLY

3、top not in方式 (不推薦)

示例:

--查詢第11-20條記錄SELECT TOP 10 menuId, *FROM sys_menu WHERE menuId NOT IN (SELECT TOP 10 menuId FROM sys_menu)

這條語句的原理是先查詢1-10條記錄的ID,然后再查詢ID不屬于這1-10條記錄的ID,并且只需要10條記錄,因為每頁大小就是10,

這就是獲取到的第11-20條記錄,這是非常簡單的一種寫法。

另外IN語句與NOT IN語句類似,這是NOT IN的寫法,但是這種寫法數據量大的話效率太低。

查詢結果如下:

通用用法

--pageIndex 表示指定頁--pageSize  表示每頁顯示的條數SELECT TOP pageSize menuId, *FROM sys_menu WHERE menuId NOT IN (SELECT TOP ((pageSize-1)*pageIndex) menuId FROM sys_menu)

4、通過升序與降序方式進行查詢分頁(不推薦)

示例:

--使用升序降序的方式分頁查詢SELECT * FROM(    SELECT TOP 10 * FROM(SELECT TOP 20 * FROM sys_menu ORDER BY menuId ASC)     AS TEMP1 ORDER BY menuId DESC)AS TEMP2 ORDER BY menuId ASC

這條語句首先查詢前20條記錄,然后在倒序查詢前10條記錄(即倒數10條記錄),

這個時候就已經獲取到了11-20條記錄,但是他們的順序是倒序,所以最后又進行升序排序。

查詢結果如下:

通用方法

--pageIndex 表示指定頁--pageSize  表示每頁顯示的條數SELECT * FROM(    SELECT TOP pageSize * FROM(SELECT TOP ((pageIndex - 1) * pageSize +(pageSize*2)) * FROM sys_menu ORDER BY menuId ASC)     AS TEMP1 ORDER BY menuId DESC)AS TEMP2 ORDER BY menuId ASC

5、采用MAX(ID)或者MIN(ID)函數(不推薦)

示例:

--MIN()函數和MAX()函數的使用--id > 第(PageIndex-1)*PageSize條記錄的id AND id <= 第PageIndex*PageSize條記錄的idSELECT TOP 10 * FROM sys_menu WHERE menuId>    (SELECT MAX(menuId) FROM(SELECT TOP 10 menuId FROM sys_menu ORDER BY menuId) AS TEMP1) --(第10條的id)

這個理解起來也簡單,先把第10條記錄的id找出來(當然這里面是直接使用MAX()進行查找,MIN()函數的用法也是類似的),

然后再對比取比第10條記錄的id大的前10條記錄即為我們需要的結果。

這里要注意開始時的邊界值調整。

查詢結果如下:

通用用法

--pageIndex 表示指定頁--pageSize  表示每頁顯示的條數SELECT TOP pageSize * FROM sys_menu WHERE menuId>    (SELECT MAX(menuId) FROM(SELECT TOP ((PageIndex-1)*PageSize) menuId FROM sys_menu ORDER BY menuId) AS TEMP1) --(第10條的id)

6、Lambda表達式分頁(推薦使用)

我們在數據庫分頁的時候,還可以在代碼里面使用lambda表達式分頁。

示例:

List<int> list = new List<int>();for (int i = 0; i < 100; i++){    list.Add(i);}//從第11條數據開始,獲取10條數據list = list.Skip(11).Take(10).ToList(); //返回值 11,12,13,14,15,16,17,18,19,20

Skip: 表示從第 (pageIndex * pageSize + 1) 條數據開始,也就是說再這之前有pageIndex * pageSize條數據。

Task:表示獲取多少條數據。

通用用法

list = list.Skip(pageIndex * pageSize +1 ).Take(pageSize).ToList();

以上就是數據查詢中經常用到的方式,

在數據庫版本支持的情況下個人推薦程度排序:offset fetch netct > lambda > ROW_NUMBER() OVER() 后面的就不推薦使用

這樣就可以配合存儲過程進行分頁了。

到此這篇關于盤點SqlServer 分頁方式和拉姆達表達式分頁的文章就介紹到這了,更多相關SqlServer 分頁拉姆達表達式分頁內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MsSQL
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
久久一日本道色综合| 国产在线精品一区二区中文| 午夜日韩视频| 日韩一二三区不卡| 日韩av一二三| 新67194成人永久网站| 亚洲欧美激情在线| 国户精品久久久久久久久久久不卡| 26uuu欧美日本| 不卡一区中文字幕| 欧美日韩国产成人在线91| 日韩电影在线观看一区| 久久亚洲二区| 日日夜夜免费精品| 久久九九电影| 日韩综合一区二区| 久久先锋影音| 日韩av二区在线播放| 久久精品女人天堂| 日韩综合在线视频| 一本色道综合亚洲| 青青草国产成人av片免费| 久久一本综合频道| 天天综合网 天天综合色| 国产日韩一区二区三区| 亚洲最大成人网4388xx| 国产精品久久九九| 午夜精品在线视频一区| 免费在线日韩av| 污片在线观看一区二区| 色哟哟在线观看一区二区三区| 午夜a成v人精品| 91黄色免费看| 91精品久久久久久久99蜜桃| 国产原创一区二区| 日韩欧美激情在线| 97国产精品videossex| 欧美精品一区男女天堂| 成人动漫一区二区三区| 久久久久九九视频| 91一区二区三区在线观看| 久久久精品免费网站| 欧美日韩国产一区精品一区| 国产精品日韩精品欧美在线| 激情欧美一区| 亚洲国产乱码最新视频 | 国产成人精品综合在线观看| 日韩一区二区三区四区| 91性感美女视频| 国产精品伦理一区二区| 999在线观看精品免费不卡网站| 亚洲成人av一区| 欧美午夜精品一区二区三区| 国产做a爰片久久毛片| xf在线a精品一区二区视频网站| 午夜久久一区| 一区二区三区在线免费观看| 91福利社在线观看| 国产91在线看| 欧美极品少妇xxxxⅹ高跟鞋| 国产视频欧美| 精品亚洲成av人在线观看| 精品毛片乱码1区2区3区| 国内精品亚洲| 日日夜夜免费精品视频| 欧美一区三区四区| 欧美日韩系列| 亚洲一二三级电影| 制服丝袜在线91| 欧美激情亚洲| 天天综合色天天| 日韩欧美国产高清| 亚洲成人自拍视频| 日本sm残虐另类| 精品理论电影在线观看| 亚洲黄色高清| 日本不卡一区二区三区高清视频| 在线播放91灌醉迷j高跟美女 | 艳妇臀荡乳欲伦亚洲一区| 欧美综合欧美视频| 成人深夜在线观看| 中文字幕在线不卡一区二区三区| 久久天堂精品| 9色porny自拍视频一区二区| 亚洲美女视频一区| 欧美日本一区二区在线观看| 欧美婷婷久久| 免费欧美在线视频| 亚洲精品一线二线三线无人区| 亚洲性感美女99在线| 免费在线观看视频一区| 久久久久国产一区二区三区四区| 国产一区二区三区高清| 国产成人精品免费在线| 亚洲激情第一区| 91精品国模一区二区三区| 精品成人久久| 国产资源精品在线观看| 国产精品传媒入口麻豆| 欧美日韩一区在线| 亚洲国产精品一区| 国产老妇另类xxxxx| 一区二区三区精品| 久久午夜电影网| 在线日韩av片| 欧美日韩综合| 国产激情一区二区三区桃花岛亚洲| 一区二区三区视频在线看| 精品国产一区二区三区久久久蜜月| 国产精品久久久久久久免费软件| 成人久久18免费网站麻豆| 亚洲欧美综合色| 91精品国产综合久久小美女| 亚洲专区免费| 欧美在线视频二区| 国产一区在线精品| 亚洲午夜激情av| 久久精品亚洲国产奇米99| 欧美无砖砖区免费| 国产精品久久久一区二区| 91在线云播放| 韩国av一区二区三区在线观看| 一区二区三区四区激情| 国产女人aaa级久久久级 | 日韩精品一区二区三区视频播放 | 久久婷婷久久一区二区三区| 精品污污网站免费看| 亚洲人成久久| 欧美jizzhd精品欧美巨大免费| 国产一区二区三区电影在线观看| 天天色综合天天| ...av二区三区久久精品| 久久综合给合久久狠狠狠97色69| 色香蕉久久蜜桃| 日韩午夜av在线| 97se亚洲国产综合自在线观| 国产尤物一区二区在线| 蜜桃在线一区二区三区| 一区二区在线观看不卡| 国产精品久久三区| 精品国产三级a在线观看| 欧美绝品在线观看成人午夜影视| 免费在线亚洲欧美| 一本色道久久综合亚洲精品不卡 | 蜜桃视频在线一区| 亚洲一区二区在线免费观看视频| 国产丝袜在线精品| 欧美成人午夜电影| 欧美日韩视频在线一区二区| 色综合久久天天| 麻豆成人在线| 亚洲一区精彩视频| 夜久久久久久| 狠狠色丁香久久综合频道| 成人av电影免费观看| 国产精品一区二区三区网站| 蜜臀国产一区二区三区在线播放 | 亚洲特黄一级片| 国产精品成人免费| 久久先锋影音av鲁色资源网| 日韩欧美美女一区二区三区| 在线播放/欧美激情| 欧美日韩久久不卡| 欧美三区在线观看| 欧美色涩在线第一页| 91久久精品国产91性色tv| 欧美亚洲一区二区三区| 国产情侣一区| 亚洲视频成人| 国产欧美91| 在线一区日本视频| 亚洲一区二区三区免费观看| 午夜在线一区二区| 亚洲在线日韩| 另类国产ts人妖高潮视频| 亚洲在线播放| 美女精品一区| 色88888久久久久久影院野外| 久久九九免费| 一本色道久久综合亚洲aⅴ蜜桃| 男女精品网站| 美女久久一区| 欧美亚洲尤物久久| 久久综合中文| 精品视频一区三区九区| 欧美日韩免费电影| 欧美高清www午色夜在线视频| 欧美福利一区二区| 欧美电影免费观看高清完整版在线观看| 欧美一区二区黄| 久久久亚洲精品一区二区三区| 国产网红主播福利一区二区| 亚洲欧洲日产国产综合网| 亚洲另类在线一区| 亚洲.国产.中文慕字在线| 日韩av电影一区| 老色鬼精品视频在线观看播放| 国产自产2019最新不卡| 波多野结衣91| 国产在线成人|