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

来源:互联网 发布:淘宝商家入驻怎么 编辑:程序博客网 时间:2024/04/28 13:26
 通过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));

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

原创粉丝点击