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

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

SQL Server下7種“數據分頁”方案全網最新最全

瀏覽:343日期:2023-03-06 14:25:55
目錄
  • 1、ROW_NUMBER() OVER()方式(SQL2012以下推薦使用)
  • 2、offset fetch next方式(SQL2012及以上的版本才支持:推薦使用 )
  • 3、top not in方式 (不推薦)
  • 4、通過升序與降序方式進行查詢分頁(不推薦)
  • 5、采用MAX(ID)或者MIN(ID)函數(不推薦)
  • 6、不依賴排序/排序Id的終極方案
  • Sql Server常見的幾種分頁方式

數據分頁往往有三種常用方案。

第一種,把數據庫中存放的相關數據,全部讀入PHP/Java/C#代碼/內存,再由代碼對其進行分頁操作(速度慢,簡易性高)。

第二種,直接在數據庫中對相關數據進行分頁操作,再把分頁后的數據輸出給代碼程序(速度中,簡易性中)。

第三種,先把數據庫中的相關數據全部讀入“緩存”或第三方工具,再由代碼程序對“緩存”或第三方工具中的數據進行讀取+分頁操作(速度快,簡易性差)。

本文下面重點闡述上述【第二種】方案在SQL Server上的使用(其它種類數據庫由于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、通過升序與降序方式進行查詢分頁(不推薦)

示例:

--查詢第11-20條記錄
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)函數(不推薦)

示例:

--查詢第11-20條記錄
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)

這個理解起來也簡單,先把第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)

上述1~5方案,再配合存儲過程,你就能制造出適合你自己的“分頁”輪子,日后反復使用。

但它們有一定自身局限性:方案1、2、5都需要依賴一個排序Id(這個Id要么是個排序列,要么是個主鍵)。方案3、4則效率太低,完全不推薦。

6、不依賴排序/排序Id的終極方案

此方案在DeveloperSharp框架中有提供(基于.Net/.Net Core/.Net Framework),方案被廣東省的多個公司/項目采用,得到了實戰驗證+穩定性。

【第一步】:從NuGet引用DeveloperSharp包。

【第二步】:創建一個用來與數據庫進行通信的“數據源類”(文本示例為:TestData.cs),內容如下:

using DeveloperSharp.Structure.Model;
using DeveloperSharp.Framework.QueryEngine;

namespace YZZ
{
    [DataSource(DatabaseType.SQLServer, "Server=localhost;Database=Test;Uid=sa;Pwd=123")]
    public class TestData : DeveloperSharp.Structure.Model.DataLayer
    {
//類中沒有任何代碼
    }
}

說 明 :“數據源類”(文本示例為:TestData.cs)必 須 繼 承 自 DeveloperSharp.Structure.Model.DataLayer 類 , 并 且 在 其 上 設 置DataSource屬 性 的 初 始 化 值 為“數據庫類型”及其“鏈接字符串”。

【第三步】:添加通過“數據源類”(TestData)調用其PagePartition方法進行數據分頁的代碼。注 意:核心代碼就一行而已!!

代碼如下:

using DeveloperSharp.Extension;//Table擴展所在的命名空間
-----------------------------
    class Program
    {
static void Main(string[] args)
{
    TestData td = new TestData();

    //分頁
    var pp = td.PagePartition("select top 5000 * from t_Order where Id>10 order by Id desc", 20, 162);

    List<Product> Products = pp.Table.ToList<Product>();
    foreach (var P in Products)
    {
Console.WriteLine(P.Name);
    }

    Console.ReadLine();
}
    }

Product類代碼如下:

 public class Product
    {
public string Id { get; set; }
public string Name { get; set; }
public int Quantity { get; set; }
    }

此處的PagePartition方法有兩個重載方法,其詳細功能說明如下:

PagePartition
聲明:public PagePiece PagePartition(string RecordSet, string Id, int PageSize, int PageIndex)
用途:分頁功能(有主鍵)
參數:(1)string RecordSet     --需要分頁的記錄集,可以是表、視圖、或者SQL語句
(2)string Id     --主鍵
(3)int PageSize     --頁面大小
(4)int PageIndex     --當前頁碼
返回:PagePiece  --頁片實體

PagePartition
聲明:public PagePiece PagePartition(string RecordSet, int PageSize, int PageIndex)
用途:分頁功能(無主鍵)
參數:(1)string RecordSet     -- 需要分頁的記錄集,可以是表、視圖、或者SQL語句
     (2)int PageSize    --頁面大小
(3)int PageIndex    --當前頁碼
返回:PagePiece  --頁片實體

注意:

(1) 當你需要分頁的數據表有“主鍵”字段時,使用“分頁功能(有主鍵)”。反之,使用“分頁功能(無主鍵)”。

(2) RecordSet是你需要分頁的“數據總集”的SQL語句。該SQL語句的形式豐富多樣,可以帶條件、排序、甚至還能是多表的聯合查詢、等。

(3) 此方法符合最開始的【第二種】方案,是在SQL Server內部進行的分頁操作。而且可以不依賴于排序/排序Id。

以上內容到此結束,下面介紹下Sql Server常見的幾種分頁方式

Sql Server常見的幾種分頁方式

⒈offset fetch next方式【SqlServer2012及以上版本支持】【推薦】

 select * from T_User
 order by id
 offset 5 rows    /*(頁數-1) * 條數 */    
 fetch next 5 rows only    /* 條數 */

⒉row_number() over()方式【SqlServer2005以上版本支持】

 select * from 
 (select *,row_number() over(order by id) as orderId from T_User) as t
 where t.orderId between 11 and 15
 /* (頁數-1)* 條數 + 1 */
 /* 頁數 * 條數 */

⒊top not in方式【適用于SqlServer2012以下版本】

 select top 5 * from T_User
 where id not in (select top 10 id from T_User)
 
 /* top 條數 */
 /* top 條數 * 頁數 */

⒋max(主鍵)方式【本質上還是top方式,適用于SqlServer2012以下版本】

 select top 5 * from T_User where id>=
 (select max(id) from (select top 6 id from T_User order by  id asc) a) 
 order by id;
 /*top 條數*/
 /*top(頁數-1)* 條數 + 1*/

分析:在數據量較大時

  top not in方式:查詢靠前的數據速度較快

  ROW_NUMBER() OVER()方式:查詢靠后的數據速度比上一種較快

  offset fetch next方式:速度穩定,優于前2種,但sql版本限制2012及以上才可使用

到此這篇關于SQL Server下7種“數據分頁”方案,全網最全的文章就介紹到這了,更多相關SQL Server數據分頁內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MsSQL
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
蜜臀久久99精品久久久久久9| 精品中文字幕一区二区三区四区| 国产精品精品| 国产一区二区三区天码| 97人人精品| 国产自产自拍视频在线观看| 国产成人精品一区二区三区免费| 欧美黄色一区| 欧美男人天堂| 亚洲韩日在线| 亚洲ab电影| 免费一级欧美片在线观看网站| 久久精品一本| 亚洲福利一区| 亚洲免费一区三区| 久久精品国产精品亚洲毛片| 久久久亚洲欧洲日产| 日韩一区电影| 三级一区在线视频先锋| 日韩激情av在线| 精品久久精品| 欧美日韩在线网站| 五月激激激综合网色播| 精品国产18久久久久久二百| 欧美日韩国产亚洲一区| 日韩午夜视频在线| 欧美亚洲日本精品| 蜜臀av一区二区三区| 欧美激情 亚洲a∨综合| 性欧美videohd高精| 男人的天堂久久精品| 国产精品网址| 欧美日韩国产一区二区三区不卡| 欧美一区激情| 欧美成人午夜| 国产精品美女午夜爽爽| 日韩中文字幕高清在线观看| 在线看片日韩| 精品国产成人| 天海翼精品一区二区三区| 国产成人精品亚洲线观看| 在线亚洲激情| 精品久久久网| 亚洲精品视频一二三区| 色综合www| 日韩精品社区| 欧美一区二区三区激情视频| 18国产精品| 午夜av一区| 国产suv精品一区二区四区视频 | 亚洲欧美视频| 精品国产乱码久久久久久1区2匹| 亚洲午夜精品久久久久久app| 国产欧美精品| 蜜桃视频一区二区三区 | 日本不卡一区二区三区| 精品视频91| 日韩激情中文字幕| 欧美不卡视频| 98精品久久久久久久| 日本午夜精品| 模特精品在线| 极品av在线| 国产精品久久久亚洲一区| 欧美sm一区| 久久99蜜桃| 日韩欧美久久| 麻豆亚洲精品| 亚洲深爱激情| 国内精品福利| 日韩精品欧美| 久久久久久久欧美精品| 亚洲精品乱码久久久久久蜜桃麻豆 | 中文一区二区| 日韩毛片视频| 亚洲深夜av| 欧美成人综合| 麻豆精品视频在线| 日韩av电影一区| 免费久久99精品国产| 国产一区观看| 久久中文视频| 国产伦理一区| 国产精品一区二区三区www| 日韩精品一区二区三区中文| 国产女优一区| 久久都是精品| 免费日韩视频| 亚洲视频电影在线| 丝袜亚洲精品中文字幕一区| 国产高清亚洲| 久久av综合| 日韩av一区二| 欧美亚洲综合视频| 欧美一区二区三区久久精品| 日本欧美在线| 免费不卡在线观看| 亚洲日韩视频| 日本不卡视频在线| 国产探花在线精品一区二区| 国产一卡不卡| 国产精品超碰| 精品久久精品| 欧美xxxx中国| 欧美片第1页| 美女网站一区| 美女国产一区| 在线午夜精品| 日韩国产在线一| 国产精品综合色区在线观看| 国产精品伦一区二区| 国产第一亚洲| 久久久久久黄| 亚洲一区日韩| 日本午夜精品| 国产精品99久久精品| 在线亚洲人成| 亚洲黄页一区| 日韩av三区| 亚洲精品永久免费视频| 国产视频一区欧美| 日韩av网站在线免费观看| 国产乱码精品| 99久久久久国产精品| 蜜臀久久久久久久| 欧美黄色一区二区| 一区二区小说| 亚洲1区在线| 久久99久久人婷婷精品综合| 欧美日韩尤物久久| 亚洲精品国产日韩| 精品三级av| 99视频精品免费观看| 日韩高清不卡在线| 国产精品蜜芽在线观看| 亚洲欧美久久久| 欧美极品中文字幕| 99久久激情| 国产精品亚洲综合色区韩国| 91精品啪在线观看国产18| 视频一区二区不卡| 美女精品在线| 亚洲国产成人精品女人| 国产精品普通话对白| 国产精品亚洲欧美日韩一区在线| 三级亚洲高清视频| 国产成人1区| 亚洲毛片在线| 日韩大片在线观看| 国产乱子精品一区二区在线观看 | 国产精品v日韩精品v欧美精品网站| 国产欧美日韩在线观看视频| 亚洲精品**中文毛片| 日本一区二区中文字幕| 1000部精品久久久久久久久| 国产麻豆精品| 综合视频一区| 好吊日精品视频| 日本一区二区高清不卡| 婷婷精品在线观看| 亚洲激情婷婷| 欧美精选视频一区二区| 综合国产在线| 婷婷丁香综合| 久久久久久久久99精品大| 国产成人免费| 国产不卡精品| 国产精品久久久久久久久久久久久久久| 婷婷综合在线| 精品久久影院| 丝袜av一区| 在线亚洲精品| 色婷婷久久久| 青青草国产成人99久久| 国产99久久| 麻豆一区在线| 日本一区二区中文字幕| 久久精品青草| 国产一区二区色噜噜| 麻豆一区二区99久久久久| 色婷婷成人网| 亚洲一区二区av| 午夜欧美精品| 999久久久亚洲| 天堂8中文在线最新版在线| 麻豆精品在线观看| 国产精品二区影院| 欧美日韩一区二区高清| 在线观看一区| 野花国产精品入口| 亚洲五月婷婷| 国产精品一区二区精品视频观看| 欧美女激情福利| 国产精品av一区二区| 四虎4545www国产精品| 色网在线免费观看| 日韩欧美午夜| 日韩大片在线| 精品日韩视频| 久久精品在线|