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却还显示它。的主要内容,如果未能解决你的问题,请参考以下文章