【C#】使用 LINQ 中的 Skip() 和 Take()进行分页,为什么要分页,分页作用是什么

欢迎来到《小5讲堂》
大家好,我是全栈小5。
这是是《C#》序列文章,每篇文章将以博主理解的角度展开讲解,
特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 场景
  • 分页方法
    • 效果
    • 代码
  • 分页目的
  • 分页考虑

场景

数据是通过分组查询出来,并且有统计值,这个统计值来源于另外一个表的统计值,
次数分组的数据量不大,最大可能也就在一千或者一万条记录,分组查询速度对性能影响不大。
此时,查询出来的一万条记录,如果都显示在页面,可能对前端渲染有一定性能影响,
因此,可在后端开发语言里进行内存分页。

分页方法

在 C# 中实现分页功能有不同的方法,其中一种常见的做法是使用 LINQ 中的 Skip() 和 Take() 方法。
假设你已经有一个包含所有数据的集合(例如 List),现在要实现一页显示 N 条数据的分页功能。

效果

  • 第一页
    在这里插入图片描述
    在这里插入图片描述
  • 第二页
    在这里插入图片描述
    在这里插入图片描述

代码

// 模拟数据集有1000条,页大小为15
int pageIndex = 1;
int pageSize = 15;
List<string> list = new List<string>();
for (int i = 1; i < 1000; i++)
{
    list.Add(Guid.NewGuid().ToString());
}
var data = list.Where(value => value.ToLower().Contains('a')).ToList();
var pageData = data.Skip((pageIndex++ - 1) * pageSize).Take(pageSize).ToList();
var pageData2 = data.Skip((pageIndex++ - 1) * pageSize).Take(pageSize).ToList();

分页目的

上面仅仅是举个简单例子,在实际场景中,针对内存操作的数据会遇到更复杂的情况,此时用这个分页也能起到不错的效果。

  • 为什么要分页
    在处理大数据量时,将所有数据一次性加载到内存中可能会导致性能和资源方面的问题。
    分页是一种常见的解决方法,它将数据划分为若干页,每页只加载一部分数据,以减少内存消耗和提高性能
  • 以下是数据分页的几个原因
  1. 提高性能
    当数据量非常庞大时,一次性加载所有数据可能会导致性能下降。通过分页,只加载当前页所需的数据,可以提高程序的响应速度和查询效率。
  2. 减少内存消耗
    将大量数据一次性加载到内存中可能会占用大量的系统资源和内存空间。通过分页,只加载当前页的数据,可以减少内存消耗,并使内存使用更高效。
  3. 改善用户体验
    分页功能可以将大量数据划分为多个页面,每次只显示一页的数据,使用户可以更方便地浏览和导航数据。
  4. 降低数据库压力
    数据库通常是存储和管理数据的主要组件。通过使用分页,只查询当前页所需的数据,可以减轻数据库的负担,提高数据库的性能和响应能力。

因此,对于大数据集合或数据库查询结果,使用分页可以解决性能和资源问题,提高程序的效率和用户体验

分页考虑

决定何时考虑分页或分库分表的关键因素是具体的应用场景和业务需求。
不同数据库的性能和可扩展性也可能会有所不同。

  • 以下是一些常见的考虑因素
    1.数据量
    数据量的增加会对查询性能产生影响。当数据量逐渐增大并且查询性能开始变差时,考虑使用分页或分库分表来提高查询效率。
    2.用户需求
    如果业务要求对大量数据进行快速、即时的分页访问,那么分页是一个合理的选择。
    3.查询响应时间
    当查询响应时间超过用户可接受的范围,例如查询时间过长导致用户等待时间过长时,可以考虑使用分页或其他优化技术。
    4.数据库负载
    当数据库负载过高,无法满足用户请求时,可以考虑使用分库分表来平衡负载。
    5.数据增长趋势
    如果数据的增长速度很快,并且预计将来会有更大的数据量,可以提前规划并考虑分页或分库分表的方案。

分页和分库分表都是一种性能优化的手段,具体业务具体分析。
最佳做法是进行性能测试和监测,了解数据库的性能瓶颈和瓶颈出现的数据量级。
根据具体情况和需求,评估是否需要采取分页、分库分表或其他性能优化措施。

总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/311417.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux 常用进阶指令

我是南城余&#xff01;阿里云开发者平台专家博士证书获得者&#xff01; 欢迎关注我的博客&#xff01;一同成长&#xff01; 一名从事运维开发的worker&#xff0c;记录分享学习。 专注于AI&#xff0c;运维开发&#xff0c;windows Linux 系统领域的分享&#xff01; 其他…

【内容管理系统】内容管理系统v1.0.0版本正式上线

目录 背景 体验 技术栈 功能菜单 示例图片 背景 为了开发一个无需开发人员&#xff0c;即可动态修改展示内容的内容管理系统&#xff0c;因此开发了当前的内容管理系统。 体验 体验地址&#xff1a;&#xff08;邮箱注册即可体验&#xff0c;部署的带宽有限&#xff0c…

java通过okhttp方式实现https请求的工具类(绕过证书验证)

目录 一、引入依赖包二、okhttp方式实现的https请求工具类2.1、跳过证书配置类2.2、okhttp方式的 https工具类 三、测试类 一、引入依赖包 引入相关依赖包 <!--okhttp依赖包--> <dependency><groupId>com.squareup.okhttp3</groupId><artifactId>…

C++标准学习--tuple

以下帖子介绍的比较详细&#xff1a; C的 tuple_c tuple-CSDN博客 tuple 是 C11 新标准里的类型&#xff0c;它是一个类似 pair 类型的模板。tuple 是一个固定大小的不同类型值的集合&#xff0c;是泛化的 std::pair。我们也可以把它当做一个通用的结构体来用&#xff0c;不需…

Electron中调用dll

截止目前Electron的官方稳定版本已经更新到了28.1.1。我在创建Electron项目时用的28.0.0版本&#xff0c;后面在项目中有用到调用dll方法的需求&#xff0c;大致的实现就是将后端给的dll文件引入到项目中&#xff0c;安装ffi-napi依赖&#xff0c;然后进行使用。但是在Electron…

js逆向第16例:猿人学第12题入门级js

文章目录 一、前言二、定位关键参数三、代码实现一、前言 任务:抓取这5页的数字,计算加和并提交结果 既然是入门级,那肯定很简单了 二、定位关键参数 控制台查看请求数据,m值应该就是关键参数了 进入堆栈 马上定位到了m值"m": btoa(yuanrenxue + window.pag…

【scala】编译build报错 “xxx is not an enclosing class“

private[sources] val creationTimeMs: Long {val session SparkSession.getActiveSession.orElse(SparkSession.getDefaultSession)require(session.isDefined)private[xxx]是访问权限控制在xxxx包的意思。 解决办法&#xff1a; 把[sources]删掉&#xff0c;或者改成和包名…

Element|Upload结合Progress实现上传展示进度条

背景 &#xff1a; 项目里的 附件上传 题型组件&#xff0c;用户在上传过程中&#xff0c;如果文件较大&#xff0c;上传过程较慢&#xff0c;而又没有一个类似 Loading... 的加载过程的话&#xff0c;会显得干愣愣的&#xff0c;用户体验较差&#xff0c;所以需要添加一个进度…

JDBC初体验(二)——增、删、改、查

本课目标 理解SQL注入的概念 掌握 PreparedStatement 接口的使用 熟练使用JDBC完成数据库的增、删、改、查操作 SQL注入 注入原理&#xff1a;利用现有应用程序&#xff0c;将&#xff08;恶意的&#xff09;SQL命令注入到后台数据库引擎执行能力&#xff0c;它可以通过在…

[C#]winform部署PaddleOCRV3推理模型

【官方框架地址】 https://github.com/PaddlePaddle/PaddleOCR.git 【算法介绍】 PaddleOCR是由百度公司推出的一款开源光学字符识别&#xff08;OCR&#xff09;工具&#xff0c;它基于深度学习框架PaddlePaddle开发。这款工具提供了一整套端到端的文字检测和识别解决方案&a…

灵魂三连问:是5G卡吗?支持5G吗?是5G套餐吗

关于5G的问题&#xff0c;小伙伴们的疑问是不是很多&#xff0c;它和4G到底有什么区别呢&#xff1f;什么是5G卡&#xff1f;什么是5G套餐&#xff1f;支持5G吗&#xff1f;什么是5G基站&#xff1f;我想大家现在一定是晕的&#xff0c;下面小编来给大家解惑&#xff01; 1&…

MySQL中datetime和timestamp的区别

datetime和timestamp的区别 相同点: 存储格式相同 datetime和timestamp两者的时间格式都是YYYY-MM-DD HH:MM:SS 不同点: 存储范围不同. datetime的范围是1000-01-01到9999-12-31. 而timestamp是从1970-01-01到2038-01-19, 即后者的时间范围很小. 与时区关系. datetime是存储…

Redis Zset类型

Redis Zset类型 Zset&#xff08;有序集合&#xff09;它是集合的一种&#xff0c;不仅可以保存元素&#xff0c;还可以为每个元素关联一个 double 类型的分数&#xff08;score&#xff09;&#xff0c;Redis 正是通过分数来为集合中的元素进行从小到大的排序。在 Zset 中&am…

1.11.。。。

1 有道云笔记 2 .h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTimerEvent> #include <QTime> #include <QTextToSpeech>namespace Ui { class Widget; }class Widget : public QWidget {Q_OBJECTpublic:explicit Widget(QW…

STL之vector

目录 vector的定义和特性 vector的定义和结构非常简单&#xff0c;它由以下几个重要的部分组成&#xff1a; vector的常用函数 vector排序去重 排序 去重 代码示例 vector的定义和特性 在c中&#xff0c;vector是一个动态数组容器&#xff0c;可以存储一系列相同类型的…

【Docker】Linux中Docker技术入门与实战及实用的常规命令

目录 一、引言 1. 说明&#xff1a; 2. Linux介绍 3. Docker简介 二、Docker三要素 1. 镜像&#xff08;Image&#xff09; 2. 容器&#xff08;Container&#xff09; 3. 仓库&#xff08;Repository&#xff09; 三、实现案例 1. 创建 2. 设置镜像 3. 开启设置 …

基于自适应遗传算法的车间调度matlab仿真,可以任意调整工件数和机器数,输出甘特图

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 4.1 编码与初始化 4.2 适应度函数 4.3 遗传操作 4.4 自适应机制 4.5 终止条件 5.完整程序 1.程序功能描述 基于自适应遗传算法的车间调度matlab仿真,可以任意调整工件数和机器数,输出甘…

【AI】搭建Windows Linux子系统(WSL2)CUDA环境

0.准备工作 Windows本机安装CUDA Driver 首先去下载页面下载驱动文件 点击Get CUDA Driver进入下载页面&#xff0c;我看下载页面跟普通驱动下载页面相同&#xff0c;感觉应该不是单独的驱动&#xff0c;只要之前显卡已经安装好了CUDA的驱动&#xff0c;就可以先省略这一步。…

4024A/B/C/D/E/F/G/H/L频谱分析仪

01 4024A/B/C/D/E/F/G/H/L频谱分析仪 产品综述&#xff1a; 4024频谱分析仪系列产品具有工作频段宽、性能指标高、扫描速度快、测试功能多、操作简便等多重优点&#xff0c;性能指标方面具有优良的平均噪声电平、相位噪声以及扫描速度&#xff0c;测量功能方面具有频谱分析、…

NetSuite 收入管理模块与总账的数据一致性检查

收入管理模块是NetSuite的一个艰深功能领域&#xff0c;能够有所实践&#xff0c;知原理懂变化的实施顾问少之又少。很高兴&#xff0c;我们的财务顾问Chris在23年底经历了一次深入的NetSuite收入管理模块的实践&#xff0c;对收入管理模块与总账递延收入和收入数据的一致性检查…