成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_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国内精品久久久久久久
日本韩国视频一区二区| 日本一道高清亚洲日美韩| 依依成人精品视频| 欧美精品三级| 日韩欧美亚洲一区二区| 国产一区在线观看麻豆| 欧美日韩国产大片| 卡一卡二国产精品 | 国产日韩欧美激情| 不卡一二三区首页| 欧美tickling网站挠脚心| 国产精品一色哟哟哟| 欧美日韩一区精品| 午夜精品一区在线观看| 亚洲神马久久| 一区二区三区精品在线| 亚洲黄网站黄| 国产精品视频一二三区| 9i在线看片成人免费| 欧美一区二区在线看| 国产成人激情av| 欧美xxxxxxxx| 成人激情动漫在线观看| 欧美成人高清电影在线| 成人激情开心网| 国产欧美日产一区| 国内一区二区三区在线视频| 国产精品免费人成网站| 激情久久一区| 自拍偷在线精品自拍偷无码专区 | 欧美亚洲图片小说| 蜜桃精品在线观看| 欧美性猛交xxxx黑人交| 久久99精品久久久久久久久久久久 | 亚洲国产精品久久久久秋霞影院| 国产伦精品一区二区三区照片91| 亚洲夂夂婷婷色拍ww47| 中日韩男男gay无套| 亚洲国产日日夜夜| 亚洲免费网址| 蜜臀av性久久久久av蜜臀妖精| 色婷婷久久综合| 久久99精品久久久久久动态图| 欧美少妇一区二区| 国产91在线观看| 亚洲国产岛国毛片在线| 国产精品日韩| 免费看日韩精品| 91精品国产91热久久久做人人| 成人99免费视频| 中文字幕不卡一区| 国产精品呻吟| 蜜桃视频一区二区三区| 91精品国产综合久久久久久漫画 | 国产亚洲综合性久久久影院| 影音先锋亚洲电影| 日韩精品一级二级| 欧美精品日韩一本| 欧美一区亚洲二区| 一区二区三区精品久久久| 在线观看www91| 不卡视频在线观看| 亚洲乱码一区二区三区在线观看| 在线亚洲高清视频| 成人深夜福利app| ...av二区三区久久精品| 久久久久国内| 国产成人aaa| 亚洲色图视频免费播放| 欧美中文字幕一区| 91老司机福利 在线| 一区二区三区美女视频| 在线不卡的av| 国内精品久久久久久久影视麻豆| 亚洲第一福利一区| 日韩欧美视频在线| 99国产精品久久久久久久成人热| 免费av成人在线| 国产三级一区二区| 久久青青草综合| 99久久99久久精品免费观看| 亚洲一区二区四区蜜桃| 91精品国产乱| 亚洲高清免费| 国内精品视频666| 中文字幕国产精品一区二区| 老司机精品视频网站| 99久久久无码国产精品| 亚洲超碰97人人做人人爱| 日韩欧美中文字幕精品| 在线一区欧美| 国产宾馆实践打屁股91| 亚洲已满18点击进入久久| 日韩网站在线看片你懂的| 亚洲成色最大综合在线| 国产精品一级黄| 一区二区免费在线| 精品久久久久久久久久久久包黑料| 亚洲视频大全| 成人av免费网站| 午夜精品福利在线| 国产日韩欧美一区二区三区综合| 91国偷自产一区二区三区观看 | 欧美日韩精品一区二区三区四区 | 日本不卡一二三区黄网| 国产农村妇女精品| 欧美在线免费播放| 亚洲精品资源| 国产成人精品在线看| 亚洲午夜久久久久久久久电影院| 欧美精品一区二区三区高清aⅴ | 欧美一区二区私人影院日本| 一区二区不卡在线视频 午夜欧美不卡'| 国产精品99久久久久久似苏梦涵| 亚洲日本电影在线| 精品三级av在线| 91精品福利视频| 99国产精品私拍| 91蜜桃网址入口| 国模一区二区三区白浆| 亚洲成av人综合在线观看| 国产亚洲成av人在线观看导航| 欧美视频精品在线观看| 国产情侣一区| 欧美精品二区三区四区免费看视频| 美女久久久精品| 亚洲色图制服诱惑| 久久精品视频网| 91精品福利在线一区二区三区| 久久中文精品| 亚洲免费激情| 色综合久久中文字幕| 老司机精品视频导航| 亚洲激情图片qvod| 久久久影院官网| 制服丝袜日韩国产| 欧美怡红院视频| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品草草| 成a人片亚洲日本久久| 久久99精品国产麻豆婷婷| 亚洲一区二区偷拍精品| 国产精品黄色在线观看| 26uuu亚洲| 日韩欧美色综合| 91精品国产乱| 欧美少妇xxx| 日本韩国精品在线| 国产伦精品一区二区三区| 亚洲成人在线| 国产一区在线免费观看| av在线不卡免费看| 国产成人综合网站| 国产精品影音先锋| 黄网站免费久久| 毛片av中文字幕一区二区| 天天影视网天天综合色在线播放| 亚洲综合在线观看视频| 亚洲精品免费在线| 亚洲精品一二三| 中文字幕综合网| 中文字幕一区二区三区蜜月| 欧美国产一区二区在线观看| 国产色综合一区| 日本一区二区视频在线| 久久久久久麻豆| 国产午夜精品一区二区三区嫩草| 精品嫩草影院久久| 精品成人免费观看| 2021国产精品久久精品| www一区二区| 国产亚洲欧美一级| 中文字幕av一区二区三区高| 国产精品伦一区| 在线亚洲成人| 欧美jjzz| 欧美午夜国产| 韩国久久久久| 99精品国产在热久久| 99av国产精品欲麻豆| 国产日韩三区| 亚洲欧美视频| 色噜噜狠狠色综合欧洲selulu| 在线亚洲一区观看| 欧美日韩国产成人在线免费| 欧美日韩日本视频| 日韩一级高清毛片| 久久久精品人体av艺术| 国产女人18水真多18精品一级做| 国产精品狼人久久影院观看方式| 国产精品国产三级国产三级人妇 | 免费成人性网站| 青青草国产成人av片免费| 欧美亚一区二区| 国产91精品在线观看| 成人激情午夜影院| 欧美精品免费观看二区| 亚洲精品精选| 可以看av的网站久久看| 欧美在线观看18|