本文技术方案支持.Net/.Net Core/.Net Framework

数据分页,几乎是任何应用系统的必备功能。但当数据量较大时,分页操作的效率就会变得很低。大数据量分页时,一个操作耗时5秒、10秒、甚至更长时间都是有可能的,但这在用户使用的角度是不可接受的……

数据分页往往有三种常用方案。

第一种,把数据库中存放的相关数据,全部读入代码/内存,再由代码对其进行分页操作。

第二种,直接在数据库中对相关数据进行分页操作,再把分页后的数据输出给代码程序。

第三种,先把数据库中的相关数据全部读入“缓存”,再由代码程序对“缓存”中的数据进行读取+分页操作。

本文下面重点阐述第一种与第二种两个解决方案,它们也都是直接基于“数据库”的。

(第三种方案虽然速度较快,但由于需要用到“缓存”这类第三方工具,且在有数据更改时需要较复杂的“数据库-缓存”同步操作,故本文暂不详述。)

◆◆第一种方案如下◆◆

从NuGet引入DeveloperSharp包,初始化IUtility工具

using DeveloperSharp.Framework.CoreUtility;
-------------------------- IUtility IU = new Utility();

IUtility内构建有3个重载的分页PagePartition方法:

PagePartition
声明:PagePiece PagePartition(DataTable Table, int PageSize, int PageIndex)
用途:分页功能
参数:(1)DataTable Table -- 需要分页的DataTable
(2)int PageSize -- 页面大小
(3)int PageIndex -- 当前页码
返回:PagePiece -- 页片实体 PagePartition
声明:PagePiece<List<T>> PagePartition<T>(IQueryable<T> DataList, int pageSize, int pageIndex) where T : class
用途:分页功能
参数:(1)IQueryable<T> DataList -- 需要分页的IQueryable
(2)int PageSize -- 页面大小
(3)int PageIndex -- 当前页码
返回:PagePiece -- 页片实体 PagePartition
声明:PagePiece<List<T>> PagePartition<T>(List<T> DataList, int pageSize, int pageIndex) where T : class
用途:分页功能
参数:(1)List<T> DataList -- 需要分页的List
(2)int PageSize -- 页面大小
(3)int PageIndex -- 当前页码
返回:PagePiece -- 页片实体

分页方法的返回值PagePiece/PagePiece<T>类,包含分页后的数据集、总页数、总数据、当前页码、等等一系列“分页”后经常会用到的数据。PagePiece/PagePiece<T>的属性的详细说明如下:

PageSize
声明:public int PageSize;
用途:int --页面大小 TotalPageNumber
声明:public int TotalPageNumber;
用途:int --总页数 TotalRecordNumber
声明:public int TotalRecordNumber;
用途:int --记录总数 CurrentStartIndex
声明:public int CurrentStartIndex;
用途:int --当前页的记录起始编号 CurrentEndIndex
声明:public int CurrentEndIndex;
用途:int --当前页的记录结束编号 CurrentPageSize
声明:public int CurrentPageSize;
用途:int --当前页的记录数量 CurrentPageIndex
声明:public int CurrentPageIndex;
用途:int --当前页码 Table
声明:public System.Data.DataTable Table;
用途:System.Data.DataTable--当前页的数据表
(或者)
DataList
声明:public List<T> DataList;
用途:List<T>--当前页的数据

◆◆第二种方案如下◆◆

为了演示“第二种分页方案”如何使用,我们首先在Visual Studio中新建一个控制台工程。然后,我们做如下三个操作。

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

【第二步】:创建一个用来与数据库进行通信的“数据源类”(文本示例为:TestData.cs),内容如下:

using DeveloperSharp.Structure.Model;//DataSource的命名空间
using DeveloperSharp.Framework.QueryEngine;//DatabaseType的命名空间 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扩展所在的命名空间(.NET6/VS2022用户,则需要在.csproj文件中的<ItemGroup>下添加<Using>标签)
-----------------------------
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语句的形式丰富多样,可以带条件、排序、甚至还能是多表的联合查询、等。

【附注】:文中所有示例均已成功运行通过!!技术交流/支持,请微信扫描二维码,备注“进群”!

最新文章

  1. PHP之Memcache缓存详解
  2. HDOJ 1358
  3. Unity Standard Assets 简介之 Vehicles
  4. SpringMVC生成任意文件,访问链接即下载
  5. NSOJ A fairy tale of the two(最小费用最大流、SPFA版本、ZKW版本)
  6. [Android] Android5.1系统自带的应用启动次数统计
  7. 利用jquery实现自动登录
  8. CDB中plug PDB
  9. 面向对象的JavaScript系列一,创建对象
  10. DBA_Oracle Erp升级时如何确定具体的Patch ID(案例)
  11. Unity之屏幕画线
  12. Verilog HDL模块的结构
  13. ISO/OSI网络体系结构和TCP/IP协议模型
  14. 异常处理try-catch-finally笔记
  15. Hive导出复杂数据到csv文件
  16. 多态,封装,反射,类内置attr属性,os操作复习
  17. js数据放入缓存,需要再调用
  18. 扩容 swap 分区
  19. Educational Codeforces Round 47 (Rated for Div. 2) 题解
  20. 【网络编程3】网络编程基础-arp请求(局域网主机扫描)

热门文章

  1. Spring Boot 整合 minio(一步到位)
  2. PMP 考试常见工具与技术点总结
  3. appium实现简单的功能测试
  4. 常用的函数式接口_Predicate接口_默认方法and和Predicate接口练习_集合接口筛选
  5. CSDN 原力(声望,影响力) -- 设计草案
  6. elastsearch整合springboot
  7. 使用Three.js实现炫酷的赛博朋克风格3D数字地球大屏 &#127760;
  8. 聊聊 C++ 右值引用 和 移动构造函数
  9. 零基础学Java(11)自定义类
  10. PHP memcache add replace set的区别和其他用法收集