C# Rows.Remove() 和 DataRow.Delete() 的区别

 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()方法即可。

 

你可能感兴趣的:(C#,解决方法,oracle)