C# 解决datagridview控件显示大量数据拖拉卡顿问题

 更新时间:2021年01月13日 14:24:34   作者:晓伟哥123  
这篇文章主要介绍了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();
      }
    }
    }

到此这篇关于C# 解决datagridview控件显示大量数据拖拉卡顿问题的文章就介绍到这了,更多相关C#  datagridview拖拉卡顿内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#6.0中10大新特性的应用和总结

    C#6.0中10大新特性的应用和总结

    微软发布C#6.0、VS2015等系列产品也有一段时间了,但是网上的教程却不多,这里真对C#6.0给大家做了一些示例,分享给大家。
    2016-03-03
  • C#读取文本文件到listbox组件的方法

    C#读取文本文件到listbox组件的方法

    这篇文章主要介绍了C#读取文本文件到listbox组件的方法,涉及C#操作文本文件及listbox组件的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-04-04
  • C#自定读取配置文件类实例

    C#自定读取配置文件类实例

    这篇文章主要介绍了C#自定读取配置文件类,实例分析了C#读取配置文件的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • C#编程高并发的几种处理方法详解

    C#编程高并发的几种处理方法详解

    这篇文章主要为大家详细介绍了C#编程高并发的几种处理方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • 详解C# partial 关键字的使用

    详解C# partial 关键字的使用

    局部类型允许我们将一个类、结构或接口分成几个部分,分别实现在几个不同的.cs文件中。接下来通过本文给大家分享C# partial 关键字的使用,感兴趣的的朋友一起看看吧
    2017-08-08
  • C#使用ODBC与OLEDB连接数据库的方法示例

    C#使用ODBC与OLEDB连接数据库的方法示例

    这篇文章主要介绍了C#使用ODBC与OLEDB连接数据库的方法,结合实例形式分析了C#基于ODBC与OLEDB实现数据库连接操作简单操作技巧,需要的朋友可以参考下
    2017-05-05
  • C#6.0新语法示例详解

    C#6.0新语法示例详解

    这篇文章主要给大家介绍了关于C#6.0新语法的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • C# 前端无插件打印导出实现方式详解

    C# 前端无插件打印导出实现方式详解

    本文讲述了使用C#实现前端无插件的打印和导出功能,介绍了相关技术和方法,适合需要在项目中实现相应功能的开发者参考
    2024-10-10
  • C#编程之依赖倒置原则DIP

    C#编程之依赖倒置原则DIP

    这篇文章介绍了C#编程之依赖倒置原则DIP,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C# wpf 无边框窗口添加阴影效果的实现

    C# wpf 无边框窗口添加阴影效果的实现

    在本篇内容中小编给大家整理了一篇关于C# wpf 无边框窗口添加阴影效果的具体方法内容,有兴趣的朋友们可以学习参考下
    2022-11-11

最新评论