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();
            }
        }
        }

今天就写到这里,记录学习的一天。望各位看官互相学习交流
本文分页代码转自

在这里插入图片描述

  • 8
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
要使用C#DataGridView控件进行数据修改,可以通过以下步骤: 1. 获取要修改的行和列的索引或DataGridViewCell对象。 2. 修改对应的单元格的值。 3. 如果需要,更新数据源以反映修改后的数据。 以下是一个示例代码,演示如何修改DataGridView控件中指定单元格的值: ```csharp // 假设dgv是一个DataGridView控件对象 // 获取要修改的单元格的行和列的索引 int rowIndex = 2; int columnIndex = 1; // 修改单元格的值 dgv.Rows[rowIndex].Cells[columnIndex].Value = "New Value"; // 如果需要,更新数据源以反映修改后的数据 if (dgv.DataSource != null) { // 获取数据源 var dataSource = dgv.DataSource as DataTable; // 假设数据源是DataTable // 修改数据源中对应的值 dataSource.Rows[rowIndex][columnIndex] = "New Value"; // 更新DataGridView控件显示修改后的数据 dgv.Refresh(); } ``` 在上述示例中,我们首先获取要修改的单元格的行和列的索引,然后使用行和列索引来访问控件中的单元格,并将其值修改为新值。如果有设置数据源,我们还可以通过获取数据源并修改其中对应的值来更新数据源,并调用DataGridView控件的Refresh()方法来刷新表格,以显示修改后的数据。 请注意,实际上,DataGridView控件中的数据是存储在数据源中的,所以在修改数据时,我们还需要考虑是否需要同步更新数据源。 希望这个示例能帮助你对C#中如何对DataGridView控件进行数据修改有一个基本的了解。如有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值