C# 解决datagridview控件显示大量数据拖拉卡顿问题
作者:晓伟哥123 发布时间:2022-03-21 12:52:24
标签:C#,datagridview,拖拉卡顿
问题描述:
由于在使用SQL查询大量的数据并一次显示到dataGridView控件,出现拖拉的时候卡顿。
解决方法:
1.首先分页。
2.其次把显示控件设置双buffer。
解决过程如下:
1.设置dataGridView双buffer代码如下,需要引用反射命名空间
Type dgvType = this.dataGridView1.GetType();
PropertyInfo pi = dgvType.GetProperty("DoubleBuffered", BindingFlags.Instance | BindingFlags.NonPublic);
pi.SetValue(this.dataGridView1, true, null);
2.自己定义分页操作控件,上一页,下一页,首页,尾页,在加载form的时候添加事件。并为他们写一个操作事件
private void Form1_Load(object sender, EventArgs e)
{
this.btn_EndPage.Click += Ctrl_Click;
this.btn_FirstPage.Click += Ctrl_Click;
this.btn_LastPage.Click += Ctrl_Click;
this.btn_NextPage.Click += Ctrl_Click;
//this.SetStyle(ControlStyles.OptimizedDoubleBuffer | ControlStyles.ResizeRedraw | ControlStyles.AllPaintingInWmPaint, true);
//this.UpdateStyles();
}
private void Ctrl_Click(object sender, EventArgs e)
{
Button btn = (Button)sender;
if (btn.Text == this.btn_EndPage.Text)
{
if (currentPage == pageCount)
{ return; }
currentPage = pageCount;
LoadPage();
}
else if (btn.Text == this.btn_FirstPage.Text)
{
if (currentPage == 1)
{ return; }
currentPage = 1;
LoadPage();
}
else if (btn.Text == this.btn_LastPage.Text)
{
if (currentPage == 1)
{ return; }
currentPage--;
LoadPage();
}
else if (btn.Text == this.btn_NextPage.Text)
{
if (currentPage == pageCount)
{ return; }
currentPage++;
LoadPage();
}
else
{
MessageBox.Show("error");
}
}
3.下面代码是分页方法,加载page
#region datagridview sort
/// <summary>
/// 每页记录数
/// </summary>
private int pageSize = 50;
/// <summary>
/// 总记录数
/// </summary>
private int recordCount = 0;
/// <summary>
/// 总页数
/// </summary>
private int pageCount = 0;
/// <summary>
/// 当前页
/// </summary>
private int currentPage = 0;
/// <summary>
/// 分页的方法
/// </summary>
/// <param name="str"></param>
private void PageSorter()
{
foreach (DataColumn col in dt.Columns)
{
DataGridViewTextBoxColumn dgvc = new DataGridViewTextBoxColumn();
dgvc.Name = "";
dgvc.DataPropertyName = "";
dgvc.HeaderText = col.ToString();
dataGridView1.Columns.Add(dgvc);
}
recordCount = dt.Rows.Count; //记录总行数
pageCount = (recordCount / pageSize);
if ((recordCount % pageSize) > 0)
{
pageCount++;
}
//默认第一页
currentPage = 1;
LoadPage();//调用加载数据的方法
}
/// <summary>
/// LoadPage方法
/// </summary>
private void LoadPage()
{
if (currentPage < 1) currentPage = 1;
if (currentPage > pageCount) currentPage = pageCount;
int beginRecord; //开始指针
int endRecord; //结束指针
DataTable dtTemp;
dtTemp = dt.Clone();
beginRecord = pageSize * (currentPage - 1);
if (currentPage == 1) beginRecord = 0;
endRecord = pageSize * currentPage;
if (currentPage == pageCount) endRecord = recordCount;
for (int i = beginRecord; i < endRecord; i++)
{
dtTemp.ImportRow(dt.Rows[i]);
}
dataGridView1.Rows.Clear();
this.lb_CurrentRow.Text = "当前页: " + currentPage.ToString() + " / " + pageCount.ToString();//当前页
this.lb_TotalRows.Text = "总行数: " + recordCount.ToString() + " 行";//总记录数
把临时table的数据插入到datagridview控件里面。
for (int i = 0; i < dtTemp.Rows.Count; i++)
{
dataGridView1.Rows.Add();
for (int j = 0; j < dtTemp.Columns.Count; j++)
dataGridView1.Rows[i].Cells[j].Value = dtTemp.Rows[i][j].ToString();
}
}
#endregion
Tips:
文中的“dt”是datatable类型的数据,给位看官可以自己创建,也可以从数据库直接获取测试数据。
Extension1:
1.设置dataGridView自增序列号
//填充序列号
private void dataGridView1_RowPostPaint_1(object sender, DataGridViewRowPostPaintEventArgs e)
{
Rectangle rectangle = new Rectangle(e.RowBounds.Location.X,
e.RowBounds.Location.Y,
dataGridView1.RowHeadersWidth - 4,
e.RowBounds.Height);
TextRenderer.DrawText(e.Graphics, (e.RowIndex + 1).ToString(),
dataGridView1.RowHeadersDefaultCellStyle.Font,
rectangle,
dataGridView1.RowHeadersDefaultCellStyle.ForeColor,
TextFormatFlags.VerticalCenter | TextFormatFlags.Right);
}
Extension2:
1.设置dataGridView自增序列号
//用委托更新data,防止卡顿。
private delegate void UpdateDataGridView(DataTable dt);
private void UpdateGV(DataTable dt)
{
if (dataGridView1.InvokeRequired)
{
//这里没有看懂,有大神可以解释下嘛
this.BeginInvoke(new UpdateDataGridView(UpdateGV), new object[] { dt });
}
else
{
dataGridView1.DataSource = dt;
dataGridView1.Refresh();
}
}
}
来源:https://blog.csdn.net/weixin_42103688/article/details/109778777


猜你喜欢
- 先如今idea中的spring项目,springBoot的项目的开发一般都是基于maven创建的项目。这大大简化我我们对于各种依赖包的管理,
- 一、Media FrameWork背景Media Framework (媒体函数库):此函数库让Android 可以播放与录制许多常见的音频
- 使用版本:spring-boot: 2.1.6.RELEASEsping: 5.1.8.RELEASEjava: openjdk 11.0.
- tokentoken的意思是“令牌”,是用户身份的验证方式,最简单的token组成:uid(用户唯一的身份标识)、time(当前时间的时间戳
- 接口隔离原则(ISP)定义:使用多个专门的接口比使用单一的总接口要好。即不要把鸡蛋都放到一个篮子里。好处:比较灵活、方便,不想实现的或不用实
- 前言碎语今天博主分享一个Kubernetes集全管理软件,也就是Kubernetes web ui。是360团队开源的一款产品,Wayne
- spring boot actuator介绍Spring Boot包含许多其他功能,可帮助您在将应用程序推送到生产环境时监视和管理应用程序。
- 这篇文章主要介绍了SpringBoot下如何实现支付宝接口的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值
- 项目中经常会使用到一对多的查询场景,但是PageHelper对这种嵌套查询的支持不够,如果是一对多的列表查询,返回的分页结果是不对的参考Gi
- 智能终端上的游戏目前风头正劲,试问哪个智能手机上没有几款企鹅公司出品的游戏呢!之前从未涉猎过游戏开发,但知道游戏开发前要挑选一款合适的游戏引
- 前言在开发过程中经常会遇到比较排序的问题,比如说对集合数组的排序等情况,基本类型都提供了默认的比较算法,如string提供了按字母进行排序,
- 本文实例讲述了Java实现自动压缩文件并加密的方法。分享给大家供大家参考,具体如下:实现功能:自动压缩并加密/**** @Title: zi
- 最近有朋友问屏幕锁定的问题,自己也在学习,网上找了下也没太详细的例子,看的资料书上也没有有关屏幕锁定程序的介绍,下个小决心,自己照着官方文档
- 前言大家都知道类的继承规则:1、派生类自动包含基类的所有成员。但对于基类的私有成员,派生类虽然继承了,但是不能在派生类中访问。2、所有的类都
- 一、概述Socket类是Java执行客户端TCP操作的基础类,这个类本身使用代码通过主机操作系统的本地TCP栈进行通信。Socket类的方法
- 本文介绍了Android BottomSheet效果的两种实现方式,分享给大家,具体如下:BottomSheet效果BottomSheet的
- 我们知道 Spring Boot 已经提供了一套默认的异常处理机制,但是 Spring Boot 提供的默认异常处理机制却并不一定适合我们实
- 原子数组原子数组有AtomicIntegerArray、AtomicLongArray、AtomicReferenceArray,主要是用来
- 本文实例讲述了C#实现动态生成静态页面的类。分享给大家供大家参考,具体如下:动态生成静态页面有许多好处,比如生成html网页有利于被搜索引擎
- SpeSqliteManager4Android改动日志2023.2.14 完成SQLiteOpenHelper 2023.2.23 完成r