电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:184日期: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
主站蜘蛛池模板: 青岛侦探调查_青岛侦探事务所_青岛调查事务所_青岛婚外情取证-青岛狄仁杰国际侦探公司 | 北京工业设计公司-产品外观设计-产品设计公司-千策良品工业设计 北京翻译公司-专业合同翻译-医学标书翻译收费标准-慕迪灵 | 釜溪印象网络 - Powered by Discuz! | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 郑州大巴车出租|中巴车租赁|旅游大巴租车|包车|郑州旅游大巴车租赁有限公司 | 优秀的临床医学知识库,临床知识库,医疗知识库,满足电子病历四级要求,免费试用 | 通风气楼_通风天窗_屋顶风机-山东美创通风设备有限公司 | 精密线材测试仪-电线电缆检测仪-苏州欣硕电子科技有限公司 | 水质监测站_水质在线分析仪_水质自动监测系统_多参数水质在线监测仪_水质传感器-山东万象环境科技有限公司 | 承插管件_不锈钢承插管件_锻钢高压管件-温州科正阀门管件有限公司 | 鼓风干燥箱_真空烘箱_高温干燥箱_恒温培养箱-上海笃特科学仪器 | 精密机械零件加工_CNC加工_精密加工_数控车床加工_精密机械加工_机械零部件加工厂 | 螺旋压榨机-刮泥机-潜水搅拌机-电动泥斗-潜水推流器-南京格林兰环保设备有限公司 | 电脑知识|软件|系统|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网 | IHDW_TOSOKU_NEMICON_EHDW系列电子手轮,HC1系列电子手轮-上海莆林电子设备有限公司 | 电动百叶窗,开窗器,电动遮阳百叶,电动开窗机生产厂家-徐州鑫友工控科技发展有限公司 | 医学模型生产厂家-显微手术模拟训练器-仿真手术模拟训练系统-北京医教科技 | 奥运星-汽车性能网评-提供个性化汽车资讯 | 垃圾处理设备_餐厨垃圾处理设备_厨余垃圾处理设备_果蔬垃圾处理设备-深圳市三盛环保科技有限公司 | 冷水机,风冷冷水机,水冷冷水机,螺杆冷水机专业制造商-上海祝松机械有限公司 | 全自动过滤器_反冲洗过滤器_自清洗过滤器_量子除垢环_量子环除垢_量子除垢 - 安士睿(北京)过滤设备有限公司 | 纳米涂料品牌 防雾抗污纳米陶瓷涂料厂家_虹瓷科技 | 德国进口电锅炉_商用电热水器_壁挂炉_电采暖器_电热锅炉[德国宝] | 成都网站建设制作_高端网站设计公司「做网站送优化推广」 | 医院专用门厂家报价-医用病房门尺寸大全-抗菌木门品牌推荐 | 翻斗式矿车|固定式矿车|曲轨侧卸式矿车|梭式矿车|矿车配件-山东卓力矿车生产厂家 | LED灯杆屏_LED广告机_户外LED广告机_智慧灯杆_智慧路灯-太龙智显科技(深圳)有限公司 | 茅茅虫AI论文写作助手-免费AIGC论文查重_写毕业论文降重 | 高柔性拖链电缆-聚氨酯卷筒电缆-柔性屏蔽电缆厂家-玖泰电缆 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 发光字|标识设计|标牌制作|精神堡垒 - 江苏苏通广告有限公司 | 伟秀电气有限公司-10kv高低压开关柜-高低压配电柜-中置柜-充气柜-欧式箱变-高压真空断路器厂家 | 体检车_移动CT车_CT检查车_CT车_深圳市艾克瑞电气有限公司移动CT体检车厂家-深圳市艾克瑞电气有限公司 | 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | 电脑知识|软件|系统|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网 | 螺旋叶片_螺旋叶片成型机_绞龙叶片_莱州源泽机械制造有限公司 | 宿松新闻网 宿松网|宿松在线|宿松门户|安徽宿松(直管县)|宿松新闻综合网站|宿松官方新闻发布 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 脱硝喷枪-氨水喷枪-尿素喷枪-河北思凯淋环保科技有限公司 |