天天看点

C# Table.Rows[index].Delete()

        如果datarow.delete()方法被调用,相应行的rowstate属性就会被设置成datarowstate.deleted。当一个行的状态是datarowstate.deleted的时候,正常情况下我们无法访问这一行。如果你需要检索已删除的原始数据,可以使用其条目属性的重载方法来传递datarowversion.original参数。

代码像这样:     

        采用datatable.rows[i].delete()删除行或在datagrid上按del键删除行后再访问该表时出现出现“不能通过已删除的行访问该行的信息”的错误。原因如下:

        delete()之后需要datatable.acceptechanges()方法确认完全删除,因为delete()只是将相应列的状态标志为删除,还可以通过datatable.rejectchanges()回滚,使该行取消删除。

        所以如果要彻底删除datarow,需要delete()和acceptechanges()方法同时使用,或者采用datatable.rows.removeat(i)方法直接删除,其中i表示行索引,还有一个就是datatable.rows.remove(datarow dr)删除指定行。

        不过使用datatable.rows.removeat(i)要注意,如果连续使用datatable.rows.removeat(0);datatable.rows.removeat(1);这时并不是删除了原表中的0,1行,而是删除0行后,原来的1行就变成了0行,所以datatable.rows.removeat(1)实际删除的是原表的2行。此时应该   i = i - 1;

        所以还是要慎用datatable.rows.removeat(i)

小注:

        行版本(datarowversion)

        行(datarow)对象有四种不同的行版本,分别是current,original,proposed和default。下面对这些行版本进行简要的说明。

        current:表示行的当前值。处于deleted状态的行不存在该行版本。

        original:表示行的原始值。处于added状态的行不存在该行版本

        proposed:表示行的建议值。不属于表的行,即处于detached状态的行存在该行版本;对于正在进行编辑的行,也存在该行版本。

        default:表示行的默认版本。处于added,modified或则unchanged状态的行的默认行版本是current;处于deleted状态的行的默认行版本是original。处于detached状态的行的默认版本是proposed。