并发冲突UpdateCommand影响0个记录”的错误

 通过datagrid修改数据,然后调用SqlDaAdapter的Update函数更新数据源,在经过新增、修改等操作后更新数据源报出“并发冲突UpdateCommand影响0个记录”的 错误,遍寻google、baidu无果,无意中发现msdn中提到更新的排序问题

  在许多情况下,以何种顺序向数据源发送通过 DataSet 作出的更改是相当重要的。例如,如果已更新现有行的主键值并且添加了具有新主键值的新行,则务必要在处理插入之前处理更新。

  可以使用 DataTable 的 Select 方法来返回仅引用具有特定 RowState 的 DataRow 数组。然后可以将返回的 DataRow 数组传递到 DataAdapter 的 Update 方法来处理已修改的行。通过指定要更新的行的子集,可以控制处理插入、更新和删除的顺序。 例如,以下代码确保首先处理表中已删除的行,然后处理已更新的行,然后处理已插入的行。 DataTable table = dataSet.Tables["Customers"];

  // First process deletes.

  adapter.Update(table.Select(null, null, DataViewRowState.Deleted));

  // Next process updates.

  adapter.Update(table.Select(null, null,

  DataViewRowState.ModifiedCurrent));

  // Finally, process inserts.

  adapter.Update(table.Select(null, null, DataViewRowState.Added));

  将原来的一条语句da.Update(ds,tableName);按照msdn 提示的顺序改成了

  da.Update(dataTable.Select(null,null,DataViewRowSt ate.Deleted));

  da.Update(dataTable.Select(null,null,DataViewRowSt ate.ModifiedCurrent));

  da.Update(dataTable.Select(null,null,DataViewRowSt ate.Added));

  经过简单的测试,并发冲突的问题貌似得到了解决

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值