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

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

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

瀏覽:185日期: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
主站蜘蛛池模板: 泰安塞纳春天装饰公司【网站】 | 热缩管切管机-超声波切带机-织带切带机-无纺布切布机-深圳市宸兴业科技有限公司 | 上海风淋室_上海风淋室厂家_上海风淋室价格_上海伯淋 | 合肥通道闸-安徽车牌识别-人脸识别系统厂家-安徽熵控智能技术有限公司 | 西安耀程造价培训机构_工程预算实训_广联达实作实操培训 | 广域铭岛Geega(际嘉)工业互联网平台-以数字科技引领行业跃迁 | 破碎机_上海破碎机_破碎机设备_破碎机厂家-上海山卓重工机械有限公司 | 上海皓越真空设备有限公司官网-真空炉-真空热压烧结炉-sps放电等离子烧结炉 | 地脚螺栓_材质_标准-永年县德联地脚螺栓厂家 | 杭州画室_十大画室_白墙画室_杭州美术培训_国美附中培训_附中考前培训_升学率高的画室_美术中考集训美术高考集训基地 | 印刷人才网 印刷、包装、造纸,中国80%的印刷企业人才招聘选印刷人才网! | MVE振动电机_MVE震动电机_MVE卧式振打电机-河南新乡德诚生产厂家 | 护栏打桩机-打桩机厂家-恒新重工 | 余姚生活网_余姚论坛_余姚市综合门户网站 | 千斤顶,液压千斤顶-力良企业,专业的液压千斤顶制造商,shliliang.com | 威廉希尔WilliamHill·足球(中国)体育官方网站 | 云南丰泰挖掘机修理厂-挖掘机维修,翻新,再制造的大型企业-云南丰泰工程机械维修有限公司 | 大鼠骨髓内皮祖细胞-小鼠神经元-无锡欣润生物科技有限公司 | 衡阳耐适防护科技有限公司——威仕盾焊接防护用品官网/焊工手套/焊接防护服/皮革防护手套 | 沉降天平_沉降粒度仪_液体比重仪-上海方瑞仪器有限公司 | 房在线-免费房产管理系统软件-二手房中介房屋房源管理系统软件 | 压砖机_电动螺旋压力机_粉末成型压力机_郑州华隆机械tel_0371-60121717 | 复盛空压机配件-空气压缩机-复盛空压机(华北)总代理 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 点焊机-缝焊机-闪光对焊机-电阻焊设备生产厂家-上海骏腾发智能设备有限公司 | 派财经_聚焦数字经济内容服务平台 | 钢丝绳探伤仪-钢丝绳检测仪-钢丝绳探伤设备-洛阳泰斯特探伤技术有限公司 | 微波萃取合成仪-电热消解器价格-北京安合美诚科学仪器有限公司 | 湖南印刷厂|长沙印刷公司|画册印刷|挂历印刷|台历印刷|杂志印刷-乐成印刷 | 日本东丽膜_反渗透膜_RO膜价格_超滤膜_纳滤膜-北京东丽阳光官网 日本细胞免疫疗法_肿瘤免疫治疗_NK细胞疗法 - 免疫密码 | 即用型透析袋,透析袋夹子,药敏纸片,L型涂布棒-上海桥星贸易有限公司 | 海峰资讯 - 专注装饰公司营销型网站建设和网络营销培训 | 重庆磨床过滤机,重庆纸带过滤机,机床伸缩钣金,重庆机床钣金护罩-重庆达鸿兴精密机械制造有限公司 | 必胜高考网_全国高考备考和志愿填报信息平台 | 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 小学教案模板_中学教师优秀教案_高中教学设计模板_教育巴巴 | 回转窑-水泥|石灰|冶金-巩义市瑞光金属制品有限责任公司 | 小型高低温循环试验箱-可程式高低温湿热交变试验箱-东莞市拓德环境测试设备有限公司 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 整合营销推广|营销网络推广公司|石家庄网站优化推广公司|智营销 好物生环保网、环保论坛 - 环保人的学习交流平台 | 米顿罗计量泵(科普)——韬铭机械 |