实现效果就是,双击单元格修改之后,数据要及时更新到数据库,然后把更新后的数据重新绑定到控件中,但是在重新绑定数据的时候会报错,错误信息为:原因是它导致对 SetCurrentCellAddressCore 函数的可重入调用。通过网上搜索,用BeginInvoke解决了这个异常。
只是拙于表达,所以把代码贴在这里:
private void dataGridView1_CellEndEdit(object sender, DataGridViewCellEventArgs e) { if (DialogResult.OK == MessageBox.Show("是否要修改", "", MessageBoxButtons.OKCancel)) { Users user = new Users(); user.UserName = this.dataGridView1.Rows[e.RowIndex].Cells[0].Value.ToString(); user.Password = this.dataGridView1.Rows[e.RowIndex].Cells[1].Value.ToString(); string sql = "update [用户表$] set 用户名='" + user.UserName + "',密码='" + user.Password + "' where 用户名='" + user.UserName + "'"; int count = OledbHelper.ExecuteNonquery(sql); if (count == 1) { MessageBox.Show("修改成功"); Thread thread = new Thread(DoWork); thread.Start(); } } } public delegate void MyInvoke(); public void DoWork() { MyInvoke mi = new MyInvoke(LoadData); this.BeginInvoke(mi); }帖子:http://topic.csdn.net/u/20120821/19/0300b744-df70-4119-8755-8ec3a6636585.html