Rows.Remove() 和 DataRow.Delete() 两个方法都是删除数据表中的某一行数据。但是两个方法还是有较大不同的:
1、数据删除结果不同:
DataRow.Delete() 只是将对应行的的状态(DataRowState)标识为删除,数据可以通过DataTable.RejectChanges() 方法实现行状态的回滚,进而恢复数据。DataRowState状态改变一次。
如果该行的 RowState 为 Added,则在调用 AcceptChanges 时,RowState 将变为 Detached,并且将从表中移除该行。
在对现有的 DataRow 使用 Delete 方法后,RowState 将变为 Deleted。 在调用 AcceptChanges 之前,它一直保持为 Deleted。 此时,将从表中移除 DataRow。
Rows.Remove() :该行中的所有数据将全部丢失,等同于先调用 DataRow.Delete() 方法,再调用 AcceptChanges()方法。DataRowState状态改变两次。
2、使用的场合不同:
1)、当数据需要使用 DataAdapter.Update() 来更新的时候,不能使用 Rows.Remove() 方法,只能使用 DataRow.Delete() 方法 。因为 Rows.Remove() 需要根据 DataRowState 的状态来更新数据 。
2)、和循环结构一起使用
Rows.Remove() 方法,每执行一次都会导致DataTable.Count 发生变化,而且每一行的行所以也会发生变化。
DataRow.Delete() 方法:在调用 AcceptChanges()方法之前,DataTable.Count 和每一行的行索引不会发生变化。
所以:foreach 循环中不能使用Rows.Remove() 方法;for 循环中如果要使用 Rows.Remove(),只能采用倒序循环来使用;DataRow.Delete() 可以在foreach 和 for 循环中使用,循环完调用 AcceptChanges()方法即可。