日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

瀏覽:330日期: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
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩欧美看国产| 精品91久久久久| 亚洲在线观看| 国产精品毛片在线看| 日韩亚洲在线| 亚洲欧美日韩视频二区| 日韩中文字幕一区二区三区| 午夜一级在线看亚洲| 丝袜美腿一区二区三区| 一区二区91| 日韩二区三区四区| 日韩黄色av| 日本午夜精品视频在线观看| 91综合久久爱com| 麻豆国产欧美日韩综合精品二区| 久久超级碰碰| 超碰超碰人人人人精品| 亚洲天堂久久| 免费人成黄页网站在线一区二区| 日韩一区网站| 久久99久久久精品欧美| 日韩综合精品| 乱人伦精品视频在线观看| 日韩三级视频| 精品72久久久久中文字幕| 久久一区二区三区喷水| 在线国产日韩| 国产欧美激情| 伊人久久高清| 亚洲一区二区小说| 欧美激情福利| 欧美va天堂| 最新亚洲国产| 国产日韩欧美一区二区三区在线观看 | 精品一区三区| 亚洲久久在线| 久久精品国产网站| 日韩一区欧美| 首页国产欧美久久| 久久伊人国产| 日韩欧美视频专区| 美女精品在线观看| 国产精品jk白丝蜜臀av小说| 日韩在线观看| 亚洲精品激情| 98精品久久久久久久| 国产精品日韩| 国产精品对白久久久久粗| 日本久久成人网| 婷婷成人av| 国产精品二区不卡| 日韩影院在线观看| 水蜜桃精品av一区二区| 亚洲激精日韩激精欧美精品| 日韩动漫一区| а√天堂中文在线资源8| 亚洲精品国产精品粉嫩| 日韩精品第一区| 奇米亚洲欧美| 亚洲激情久久| 精品国产一级| 亚洲小说春色综合另类电影| 91视频久久| 色婷婷成人网| 播放一区二区| 国产毛片一区二区三区| 国产一级久久| 日韩欧美一区二区三区在线观看 | 九九综合九九| 国产精品国码视频| 老色鬼久久亚洲一区二区| 激情国产在线| 国产精品美女在线观看直播| 亚洲综合不卡| 欧美日韩免费观看视频| 久久国产日韩欧美精品| 制服诱惑一区二区| 成人片免费看| 美女精品一区二区| 亚洲精品日韩久久| 婷婷成人在线| 精品伊人久久| 日韩av中文字幕一区| 欧美成人亚洲| 中文在线资源| 麻豆91在线播放| 日韩精品a在线观看91| 日韩午夜免费| 1000部精品久久久久久久久| 国产精品久久久久久久久久10秀| 国产亚洲欧美日韩精品一区二区三区 | 激情欧美一区二区三区| 福利一区在线| 国产精品第一| 欧美在线日韩| 亚洲ww精品| 亚洲综合丁香| 国产91精品对白在线播放| 国产一区二区三区四区大秀| 国产亚洲欧美日韩精品一区二区三区| 美日韩精品视频| 久久国产日韩| 精品久久视频| 久久成人高清| 欧美精品中文| 日韩福利视频一区| 亚洲精品一区二区在线播放∴| 狠狠干综合网| 国产精品av一区二区| 婷婷激情一区| 色一区二区三区| 久久久91麻豆精品国产一区| 国产日韩欧美三级| 国产欧美在线| 国产美女精品视频免费播放软件| 亚洲精品四区| 日韩精品一级二级| 国产精品日本| 国产精品毛片在线| 亚洲精品小说| 日韩视频一区| 蘑菇福利视频一区播放| 亚洲免费中文| 蜜臀精品久久久久久蜜臀| 久久成人一区| 亚洲久久一区| 日韩高清在线不卡| 91精品一区| 久久成人福利| 日韩av在线播放网址| 天堂av在线| 色偷偷偷在线视频播放| 亚洲91久久| 欧美特黄一区| 在线看片一区| 国产精品永久| 国产在线观看91一区二区三区| 97精品国产一区二区三区| 丝袜美腿诱惑一区二区三区 | 国产aⅴ精品一区二区三区久久| 超碰成人av| 国产在线成人| 综合激情网站| 日韩一区二区三区精品| 国产乱码精品一区二区三区四区| 精品精品久久| 亚洲福利免费| 亚洲精品看片| 国产精品777777在线播放 | 精品国产精品久久一区免费式| 吉吉日韩欧美| 日韩天堂av| 青青草国产精品亚洲专区无| 另类综合日韩欧美亚洲| 欧美韩日一区| 亚洲黄色在线| 亚洲一区有码| 欧美激情久久久久久久久久久| 亚洲精品**中文毛片| 在线成人直播| 青青草91久久久久久久久| 国产在视频一区二区三区吞精| 激情综合激情| 欧美亚洲人成在线| 亚洲女同av| 一区二区三区国产盗摄| 国产精品igao视频网网址不卡日韩 | 亚洲精品亚洲人成在线观看| 国产精品丝袜在线播放| 久久久久久久欧美精品| 97精品一区二区| 蜜臀av亚洲一区中文字幕| 69堂免费精品视频在线播放| 国产精品99一区二区三| 亚洲欧美日韩精品一区二区| 国产欧美午夜| 1024精品一区二区三区| 91精品丝袜国产高跟在线| 日韩在线中文| 日日夜夜免费精品视频| 欧美激情国产在线| 亚洲三级视频| 久久久水蜜桃av免费网站| 亚洲毛片在线免费| 国产在线|日韩| 久久国产精品免费精品3p| 欧美亚洲国产激情| 97久久精品| 久久久久91| 国产乱子精品一区二区在线观看| 在线日韩av| 美女视频黄 久久| 亚洲视频播放| 色综合五月天| 日韩1区2区日韩1区2区| 亚洲va在线| 精品国产欧美日韩| 五月国产精品| 香蕉国产精品| 亚洲精品**中文毛片|