datagridview行删除时,之前都能删除,但就是最后一行删除时,数据库删除了,但datagridview却还显示它。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了datagridview行删除时,之前都能删除,但就是最后一行删除时,数据库删除了,但datagridview却还显示它。相关的知识,希望对你有一定的参考价值。

这应该是DataGridView的RowIndex问题吧,太久没做CS了.看你的说法应该是多行删除.因为单行删除重新绑定数据源不应该存在这个问题.如果是多行删除的话,在DataGridView中设置一个隐藏列或者找一列是唯一ID的列,把需要删除的数据先获取出来存放在List或者其他数组中,选中行获取完毕后,循环你的List或者数组,再去找到DataGridView对应的行删除即可. 参考技术A 每次删除后要执行刷新。dataGridView控件提供了刷新的函数。 参考技术B 没事 刷乐蛙也追问

什么意思?

DataGridView使用技巧四:删除行操作

一、无条件的删除行

默认时,DataGridView是允许用户进行行的删除操作,选中要删除的行,按Delete键可以删除,该操作没有任何提示(只是删除界面显示的数据,不会真实删除数据库中的数据)。如果设置DataGridView对象的AllowUserToDeleteRows属性为False,用户将被禁止删除行。

示例:禁止DataGridView删除行

1 this.dgv_PropDemo.AllowUserToDeleteRows = false;

但是,通过行的Remove或者RemoveAt还是可以删除行的。

示例:

1 //删除选中的第一行
2 this.dgv_PropDemo.Rows.Remove(this.dgv_PropDemo.SelectedRows[0]);

如果DataGridView绑定的是DataView的话,通过DataView.AllowDelete也可以控制行的删除。

二、删除行时的条件判断

用户在删除行的时候,将会引发DataGridView.UserDeletingRow事件。在这个事件里,可以判断条件并取消删除操作。(需要将AllowUserToDeleteRows设置为true,并且是使用键盘的delete键时才会触发该事件)。

UserDeletingRow:行被删除时触发。

UserDeletedRow:行被删除以后触发。执行顺序:先执行UserDeletingRow事件后执行UserDeletedRow事件。

示例:

 1 private void dgv_PropDemo_UserDeletingRow(object sender, DataGridViewRowCancelEventArgs e)
 2 {
 3        //删除前确认
 4        if (MessageBox.Show("确认要删除选中的行吗?", "删除确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
 5          {
 6              //如果不是Ok,则删除
 7              e.Cancel = true;
 8          }
 9 }
10 
11 private void dgv_PropDemo_UserDeletedRow(object sender, DataGridViewRowEventArgs e)
12 {
13         MessageBox.Show("该行已被删除");
14 }

三、删除选中的行

示例:

1 foreach (DataGridViewRow row in this.dgv_PropDemo.SelectedRows)
2 {
3       if (!row.IsNewRow)
4       {
5            this.dgv_PropDemo.Rows.Remove(row);
6       }
7 }

 

以上是关于datagridview行删除时,之前都能删除,但就是最后一行删除时,数据库删除了,但datagridview却还显示它。的主要内容,如果未能解决你的问题,请参考以下文章

Winform datagridview checkbox全选问题

怎么删除datagridview中选中的行啊

DataGridView使用技巧四:删除行操作

c# datagridview 删除行

删除DataGridView选中行并更新数据库

如何在datagridview中添加行,删除行,插入行???