C# Table.Rows[index].Delete()
代码像这样:
if (typedDataRow.RowState == DataRowState.Deleted) id = (string)typedDataRow["CustomerID", 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。
以上就是C# Table.Rows[index].Delete()的内容,更多相关内容请关注PHP中文网(www.php.cn)!
上一篇: mysql图文安装教程_MySQL
推荐阅读
-
C#删除只读文件或文件夹(解决File.Delete无法删除文件)
-
C#删除只读文件或文件夹(解决File.Delete无法删除文件)
-
解决ElasticSearch 报错blocked by: [FORBIDDEN/12/index read-only / allow delete (api)];
-
手把手教你使用C#连接并操作数据库SQLite,创建数据库,创建表,插入INSERT,查询SELECT,删除DELETE(持续更新)
-
C# 使用LINQ、泛型、Index函数优化switch(或者多条if)语句
-
C# index of 用法(转载)
-
C# Table.Rows[index].Delete()
-
C# 使用LINQ、泛型、Index函数优化switch(或者多条if)语句
-
C# index of 用法(转载)
-
C# Table.Rows[index].Delete()