久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

盤(pán)點(diǎn)SqlServer 分頁(yè)方式和拉姆達(dá)表達(dá)式分頁(yè)

瀏覽:183日期:2023-03-06 14:25:58
目錄
  • 1、ROW_NUMBER() OVER()方式(SQL2012以下推薦使用)
  • 2、offset fetch next方式(SQL2012及以上的版本才支持:推薦使用 )
  • 3、top not in方式 (不推薦)
  • 4、通過(guò)升序與降序方式進(jìn)行查詢分頁(yè)(不推薦)
  • 5、采用MAX(ID)或者M(jìn)IN(ID)函數(shù)(不推薦)
  • 6、Lambda表達(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

用子查詢新增一列行號(hào)(ROW_NUMBER)RowId查詢,比較高效的查詢方式,只有在SQL Server2005或更高版本才支持。

BETWEEN 1 AND 10 是指查詢第1到第10條數(shù)據(jù)(閉區(qū)間),在這里面需要注意的是OVER的括號(hào)里面可以寫(xiě)多個(gè)排序字段。

查詢結(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方式查詢,最高效的查詢方式,只有在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ò)。

查詢結(jié)果如下:

通用用法

--pageIndex 表示指定頁(yè)--pageSize  表示每頁(yè)顯示的條數(shù)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)

這條語(yǔ)句的原理是先查詢1-10條記錄的ID,然后再查詢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ù)量大的話效率太低。

查詢結(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)行查詢分頁(yè)(不推薦)

示例:

--使用升序降序的方式分頁(yè)查詢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ǔ)句首先查詢前20條記錄,然后在倒序查詢前10條記錄(即倒數(shù)10條記錄),

這個(gè)時(shí)候就已經(jīng)獲取到了11-20條記錄,但是他們的順序是倒序,所以最后又進(jì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條記錄的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)

這個(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)整。

查詢結(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ù)查詢中經(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)文章希望大家以后多多支持!

標(biāo)簽: MsSQL
主站蜘蛛池模板: 布拖县| 涡阳县| 吉林省| 凌源市| 凯里市| 仁化县| 保山市| 天水市| 伊通| 盐边县| 金昌市| 永丰县| 玉田县| 象州县| 北票市| 浏阳市| 综艺| 绿春县| 湟源县| 湖北省| 塔城市| 稻城县| 盖州市| 汶上县| 保山市| 咸丰县| 洪湖市| 龙南县| 丰顺县| 资源县| 琼海市| 建宁县| 永修县| 望奎县| 通州市| 巴楚县| 长宁县| 枣阳市| 泗洪县| 田阳县| 关岭|