首页 > 杂文归档 正文
C# 解决datagridview控件显示大量数据拖拉卡顿问题

 2021-01-13 18:00:08      

问题描述:


由于在使用SQL查询大量的数据并一次显示到dataGridView控件,出现拖拉的时候卡顿。


解决方法:

1.首先分页。

2.其次把显示控件设置双buffer。
解决过程如下:
1.

问题描述:

由于在使用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;


      https://this.SetStyle(ControlStyles.OptimizedDoubleBuffer | ControlStyles.ResizeRedraw | ControlStyles.AllPaintingInWmPaint, true);
      https://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

    https:/// <summary>
    https:/// 每页记录数
    https:/// </summary>
    private int pageSize = 50;

    https:/// <summary>
    https:/// 总记录数
    https:/// </summary>
    private int recordCount = 0;

    https:/// <summary>
    https:/// 总页数
    https:/// </summary>
    private int pageCount = 0;

    https:/// <summary>
    https:/// 当前页
    https:/// </summary>
    private int currentPage = 0;


    https:/// <summary>
    https:/// 分页的方法
    https:/// </summary>
    https:/// <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;   https://记录总行数
      pageCount = (recordCount / pageSize);
      if ((recordCount % pageSize) > 0)
      {
pageCount++;
      }
      https://默认第一页
      currentPage = 1;
      LoadPage();https://调用加载数据的方法
    }


    https:/// <summary>
    https:/// LoadPage方法
    https:/// </summary>
    private void LoadPage()
    {
      if (currentPage < 1) currentPage = 1;
      if (currentPage > pageCount) currentPage = pageCount;

      int beginRecord;  https://开始指针
      int endRecord;   https://结束指针
      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();https://当前页
      this.lb_TotalRows.Text = "总行数: " + recordCount.ToString() + " 行";https://总记录数
      


      把临时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自增序列号

 https://填充序列号
    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自增序列号

    https://用委托更新data,防止卡顿。
    private delegate void UpdateDataGridView(DataTable dt);
    private void UpdateGV(DataTable dt)
    {
      if (dataGridView1.InvokeRequired)
      {
       https://这里没有看懂,有大神可以解释下嘛
this.BeginInvoke(new UpdateDataGridView(UpdateGV), new object[] { dt });
      }
      else
      {
dataGridView1.DataSource = dt;
dataGridView1.Refresh();
      }
    }
    }

原文链接:http://www.yuepc.com/a/1764.html

http://www.yuepc.com 为 “沈一博客” 唯一官方服务平台,请勿相信其他任何渠道。

  相关文章
杂文归档

第一种是用数据流导出:


#region
SaveFileDialog saveFileDialog = new SaveFileDialog();
saveFileDialog.Filter = "Execl files (*.xls)|*.xls";
sav

2021-01-13  0
杂文归档

下载代码Cookie池(这里主要是微博登录,也可以自己配置置其他的站点网址)
下载代码GitHub:https:https://github.com/Python3WebSpider/CookiesPool

下载安装过后注意看网页下面

2021-01-13  1
杂文归档

气泡图(Bubble Chart)是可用于展示三个变量之间的关系。通过绘制x 值, y 值和大小值即可确定图表中气泡的坐标及大小。下面通过后端C#代码及VB.NET代码展示如何来实现在Excel中

2021-01-12  2
杂文归档

利用psql启动数据库


[postgres@highgo ~]$ pg_ctl start

查看系统中运行的postgres进程


#ps -ef | grep postgres

连接postgresql数据库


#psql -h 127.0.0.1 -d pos

2021-01-11  2
杂文归档

当PostgreSQL启用日志时,若postgresql.conf日志的相关参数还使用默认值的话磁盘很容易被撑爆.因此在启用了logging_collector参数时,需要对其它相关的参数进行调整.
系统默

2021-01-11  1
杂文归档

一、构建 Docker 环境


1、创建 dockerfile


FROM centos:latest
RUN groupadd -r redis && useradd -r -g redis redis
RUN yum -y update && yum -y install epel-rele

2021-01-10  2
杂文归档

本文实例为大家分享了JavaScript实现购物车的具体代码,供大家参考,具体内容如下
效果:

代码:


<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<

2021-01-10  3
杂文归档

项目介绍
springboot搭建的访客管理系统,针对高端基地做严格把控来访人员信息管理,用户后端可以设置多个管理员帐号,给予不同部门的管理层使用,用户管理可以增加/修改内部成员的

2021-01-10  1
杂文归档

首先更新yum环境


yum -y update

1、安装gcc环境


yum -y install gcc

2、首先下载redis安装包


cd /home/apps
wget http:https://download.redis.io/releases/redis-

2021-01-08  1
杂文归档

一、简介


开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。
二、参数说明


slow_query_log 慢查询开启

2021-01-07  1
  • 评论列表

发表评论:


  • 官方微信

    扫码二维码

    获取最新动态

    我的blog

  • 返回顶部