0

0

C#怎么实现DataGridView分页_C#如何展示海量数据【指南】

穿越時空

穿越時空

发布时间:2026-03-19 10:09:32

|

349人浏览过

|

来源于php中文网

原创

DataGridView不支持内置分页,必须将分页逻辑前置到数据库层,仅加载当前页数据;禁用AutoSizeMode避免重算行高;BindingSource“假分页”实为内存切片,会导致性能恶化。

c#怎么实现datagridview分页_c#如何展示海量数据【指南】

DataGridView 本身不支持分页,硬塞几万行会卡死

别被“分页”俩字骗了——DataGridView 是个展示控件,不是数据库查询器。它没内置分页逻辑,所有数据加载进内存后才渲染。一旦你 DataTable.Load()DataSource = list 塞入几万条,UI 线程直接卡住,滚动条拖不动,双击无响应,甚至触发 Windows 的“未响应”弹窗。

真正可行的路径只有一条:把分页逻辑前置到数据层,让 DataGridView 永远只看到当前页的几百条数据。

  • SqlDataReader + OFFSET FETCH(SQL Server 2012+)或 ROW_NUMBER() 分页查;MySQL 用 LIMIT offset, size;PostgreSQL 同理
  • 避免 SELECT * FROM huge_table 全表加载再用 C# 切片——这等于把压力从 DB 转移到 UI 线程,更慢
  • 禁用 AutoSizeModeAllCellsDisplayedCells,否则每页刷新都会触发行高重算,卡上加卡

用 BindingSource 做“假分页”是典型误区

有人试过把全部数据一次性读进 List<T>,再用 BindingSourcePositionCount 模拟翻页——这根本不是分页,只是在内存里切数组。用户点“下一页”,你仍得遍历整个列表找下 50 条,且 DataGridView 还要重绘全部行(哪怕只显示其中几十行)。

现象很典型:BindingSource.MoveNext() 越往后越慢,内存占用飙升,GC 频繁,Ctrl+C 复制整列都延迟半秒以上。

  • BindingSource 适合小数据(
  • 它的 FilterSort 是客户端操作,数据量一大就变拖拉机
  • 若真要用,至少配合 VirtualMode = true,但这时你得自己实现 CellValueNeeded,反而绕回手动分页逻辑

推荐做法:服务端分页 + 手动刷新 DataSource

核心就是三件事:用户点“第3页”,发请求查第3页数据,清空旧 DataSource,赋新 DataTableBindingList<T>。UI 层不碰原始数据集,只管展示。

像素蛋糕PixCake
像素蛋糕PixCake

像素级AI图像精修软件

下载

关键细节藏在参数和时机里:

  • 分页参数必须用 int pageIndexint pageSize,别传“第几页”字符串,防止解析失败导致 OFFSET 0 无限循环
  • 查完立刻设 dataGridView1.DataSource = null,再赋新值,否则旧引用残留可能引发 ObjectDisposedException
  • 如果用了 DataGridViewTextBoxColumn 自定义列,确保 DataPropertyName 和返回字段名完全一致(区分大小写),否则列空着不显示
  • 启用 DoubleBuffered(需反射设置)可缓解翻页闪屏,但治标不治本;真正的流畅来自减少单次渲染量
var data = await LoadPageAsync(pageIndex: 3, pageSize: 50);
dataGridView1.DataSource = null;
dataGridView1.DataSource = data; // data 是 DataTable 或 List<Order>

滚动加载(Infinite Scroll)比页码更难搞,慎选

用户滚到底部自动加载下一页?听着高级,实操掉坑率极高。因为 DataGridView 没提供“滚动接近底部”的可靠事件,Scroll 事件触发太频繁,FirstDisplayedScrollingRowIndex 在虚拟模式下又不准。

常见崩法:RowsAdded 里再发请求,结果回调回来又触发 RowsAdded,无限递归;或者并发请求没控制,页面乱序插入。

  • 真要上滚动加载,必须加防抖:记录上一次请求时间,间隔
  • 禁用用户手动翻页控件(页码跳转),否则和滚动逻辑冲突
  • 首次加载建议固定 100 行,而不是“尽可能多”,否则初始渲染就卡
  • 最稳的方案仍是传统页码——用户明确知道“共多少页”,也方便跳转、打印、导出

分页的本质是限制数据流动的管道口径,不是给 UI 控件贴补丁。最容易被忽略的,是连数据库查询语句都没加 ORDER BY 就直接 OFFSET ——结果每翻一页顺序都变,用户以为数据丢了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c#是什么意思
c#是什么意思

C#是一种通用的面向对象编程语言,它在.NET框架上运行,可用于开发各种类型的应用程序。本专题为大家提供c#相关的各种文章、以及下载和课程。

279

2023.08.08

什么是c#
什么是c#

C#(读作C Sharp)是一种现代的、通用的、面向对象的编程语言。它由微软公司开发,于2000年首次发布,主要用于开发Windows桌面应用程序、Web应用程序、移动应用程序以及游戏开发等领域。C#是一种类型安全和托管的编程语言,它结合了C++的强大性能和C语言的简单易学特点,并引入了许多新的特性和概念,如委托、属性、泛型和异步编程等,以提高开发效率和代码可维护性。

185

2023.08.31

C#中base关键字的用法
C#中base关键字的用法

在C#中,base关键字用于访问当前类的基类成员,这包括基类的字段、属性、方法、构造函数、索引器以及事件。想了解更多C#的相关内容,可以阅读本专题下面的文章。

327

2024.03.13

C#Task用法
C#Task用法

Task在C#中是用于表示异步操作的对象,它位于System.Threading.Tasks命名空间中。想了解更多C#中各种用法的相关内容,可以阅读本专题下面的文章。

380

2024.03.14

C# 并发与异步编程
C# 并发与异步编程

本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。

29

2026.02.03

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

107

2026.02.06

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

416

2026.03.11

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1091

2023.08.02

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.6万人学习

C 教程
C 教程

共75课时 | 5.6万人学习

C++教程
C++教程

共115课时 | 22.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号