盤(pán)點(diǎn)SqlServer?分頁(yè)方式和拉姆達(dá)表達(dá)式分頁(yè)
現(xiàn)在基本上大家都在使用各種輪子自帶的分頁(yè),大家是否還記得sql分頁(yè)怎么寫(xiě)?
今天我們就來(lái)盤(pán)一盤(pán)怎么寫(xiě)和用哪種方式寫(xiě)。
歡迎大家評(píng)論區(qū)討論。
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
用子查詢(xún)新增一列行號(hào)(ROW_NUMBER)RowId查詢(xún),比較高效的查詢(xún)方式,只有在SQL Server2005或更高版本才支持。
BETWEEN 1 AND 10 是指查詢(xún)第1到第10條數(shù)據(jù)(閉區(qū)間),在這里面需要注意的是OVER的括號(hào)里面可以寫(xiě)多個(gè)排序字段。
查詢(xún)結(jié)果如下:
通用用法
--pageIndex 表示指定頁(yè) --pageSize 表示每頁(yè)顯示的條數(shù) 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方式查詢(xún),最高效的查詢(xún)方式,只有在SQL Server2012或更高版本才支持 SELECT * FROM sys_menu ORDER BY menuId offset 0 ROWS FETCH NEXT 10 ROWS ONLY
offset 是跳過(guò)多少行,
next是取接下來(lái)的多少行,
句式 offset...rows fetch nect ..rows only ,注意rows和末尾的only 不要寫(xiě)漏掉了,并且這種方式必須要接著Order by XX 使用,不然會(huì)報(bào)錯(cuò)。
查詢(xún)結(jié)果如下:
通用用法
--pageIndex 表示指定頁(yè) --pageSize 表示每頁(yè)顯示的條數(shù) SELECT * FROM 表名 ORDER BY 排序字段 offset ((pageIndex - 1) * pageSize) ROWS FETCH NEXT pageSize ROWS ONLY
3、top not in方式 (不推薦)
示例:
--查詢(xún)第11-20條記錄 SELECT TOP 10 menuId, * FROM sys_menu WHERE menuId NOT IN (SELECT TOP 10 menuId FROM sys_menu)
這條語(yǔ)句的原理是先查詢(xún)1-10條記錄的ID,然后再查詢(xún)ID不屬于這1-10條記錄的ID,并且只需要10條記錄,因?yàn)槊宽?yè)大小就是10,
這就是獲取到的第11-20條記錄,這是非常簡(jiǎn)單的一種寫(xiě)法。
另外IN語(yǔ)句與NOT IN語(yǔ)句類(lèi)似,這是NOT IN的寫(xiě)法,但是這種寫(xiě)法數(shù)據(jù)量大的話效率太低。
查詢(xún)結(jié)果如下:
通用用法
--pageIndex 表示指定頁(yè) --pageSize 表示每頁(yè)顯示的條數(shù) SELECT TOP pageSize menuId, * FROM sys_menu WHERE menuId NOT IN (SELECT TOP ((pageSize-1)*pageIndex) menuId FROM sys_menu)
4、通過(guò)升序與降序方式進(jìn)行查詢(xún)分頁(yè)(不推薦)
示例:
--使用升序降序的方式分頁(yè)查詢(xún) 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
這條語(yǔ)句首先查詢(xún)前20條記錄,然后在倒序查詢(xún)前10條記錄(即倒數(shù)10條記錄),
這個(gè)時(shí)候就已經(jīng)獲取到了11-20條記錄,但是他們的順序是倒序,所以最后又進(jìn)行升序排序。
查詢(xún)結(jié)果如下:
通用方法
--pageIndex 表示指定頁(yè) --pageSize 表示每頁(yè)顯示的條數(shù) 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)或者M(jìn)IN(ID)函數(shù)(不推薦)
示例:
--MIN()函數(shù)和MAX()函數(shù)的使用 --id > 第(PageIndex-1)*PageSize條記錄的id AND id <= 第PageIndex*PageSize條記錄的id SELECT 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)
這個(gè)理解起來(lái)也簡(jiǎn)單,先把第10條記錄的id找出來(lái)(當(dāng)然這里面是直接使用MAX()進(jìn)行查找,MIN()函數(shù)的用法也是類(lèi)似的),
然后再對(duì)比取比第10條記錄的id大的前10條記錄即為我們需要的結(jié)果。
這里要注意開(kāi)始時(shí)的邊界值調(diào)整。
查詢(xún)結(jié)果如下:
通用用法
--pageIndex 表示指定頁(yè) --pageSize 表示每頁(yè)顯示的條數(shù) 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表達(dá)式分頁(yè)(推薦使用)
我們?cè)跀?shù)據(jù)庫(kù)分頁(yè)的時(shí)候,還可以在代碼里面使用lambda表達(dá)式分頁(yè)。
示例:
List<int> list = new List<int>(); for (int i = 0; i < 100; i++) { list.Add(i); } //從第11條數(shù)據(jù)開(kāi)始,獲取10條數(shù)據(jù) list = list.Skip(11).Take(10).ToList(); //返回值 11,12,13,14,15,16,17,18,19,20
Skip: 表示從第 (pageIndex * pageSize + 1) 條數(shù)據(jù)開(kāi)始,也就是說(shuō)再這之前有pageIndex * pageSize條數(shù)據(jù)。
Task:表示獲取多少條數(shù)據(jù)。
通用用法
list = list.Skip(pageIndex * pageSize +1 ).Take(pageSize).ToList();
以上就是數(shù)據(jù)查詢(xún)中經(jīng)常用到的方式,
在數(shù)據(jù)庫(kù)版本支持的情況下個(gè)人推薦程度排序:offset fetch netct > lambda > ROW_NUMBER() OVER() ,后面的就不推薦使用 。
這樣就可以配合存儲(chǔ)過(guò)程進(jìn)行分頁(yè)了。
到此這篇關(guān)于盤(pán)點(diǎn)SqlServer 分頁(yè)方式和拉姆達(dá)表達(dá)式分頁(yè)的文章就介紹到這了,更多相關(guān)SqlServer 分頁(yè)拉姆達(dá)表達(dá)式分頁(yè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MSSQL 計(jì)算兩個(gè)日期相差的工作天數(shù)的語(yǔ)句
MSSQL計(jì)算兩個(gè)日期相差的工作天數(shù)的代碼,需要的朋友可以參考下。2009-09-09數(shù)據(jù)庫(kù)中聚簇索引與非聚簇索引的區(qū)別[圖文]
在《數(shù)據(jù)庫(kù)原理》里面,對(duì)聚簇索引的解釋是:聚簇索引的順序就是數(shù)據(jù)的物理存儲(chǔ)順序,而對(duì)非聚簇索引的解釋是:索引順序與數(shù)據(jù)物理排列順序無(wú)關(guān)。正式因?yàn)槿绱?,所以一個(gè)表最多只能有一個(gè)聚簇索引2012-02-02淺析SQL Server的聚焦使用索引和查詢(xún)執(zhí)行計(jì)劃
本文通過(guò)介紹默認(rèn)使用索引、強(qiáng)制使用聚集索引、強(qiáng)制使用非聚集索引讓我們知道對(duì)于檢索所有列結(jié)果集使用主鍵的聚集索引是最佳選擇。有興趣的朋友可以看下2016-12-12SQL Server 2016 無(wú)域群集配置 AlwaysON 可用性組圖文教程
這篇文章主要介紹了SQL Server 2016 無(wú)域群集配置 AlwaysON 可用性組圖文教程,需要的朋友可以參考下2017-04-04自己收集比較強(qiáng)大的分頁(yè)存儲(chǔ)過(guò)程 推薦
這兩天幫朋友修改一個(gè)項(xiàng)目,看到一個(gè)存儲(chǔ)過(guò)程,感覺(jué)性能非常高。于是,整合自己以前搜集的比較好的存儲(chǔ)過(guò)程,拿來(lái)跟大家分享下2011-11-11SQLyog連接MySQL8.0報(bào)2058錯(cuò)誤的完美解決方法
這篇文章主要介紹了SQLyog連接MySQL8.0報(bào)2058錯(cuò)誤的完美解決方法,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10使用 SQL 服務(wù)器時(shí),"評(píng)估期已過(guò)期"錯(cuò)誤消息(解決方法)
這篇文章主要介紹了使用 SQL 服務(wù)器時(shí),"評(píng)估期已過(guò)期"錯(cuò)誤消息,本文分步驟給大家分享解決方法,需要的朋友可以參考下2019-12-12SQL 判斷給定日期值(或時(shí)間段)所在星期的星期一和星期天的日期
最近報(bào)表要用到一項(xiàng)功能,需要把數(shù)據(jù)源根據(jù)記錄發(fā)生日期所在的星期序列進(jìn)行分組。因此就寫(xiě)了兩個(gè)相關(guān)SQL Function進(jìn)行調(diào)用。2011-10-10