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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值