通过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));
经过简单的测试,并发冲突的问题貌似得到了解决
在许多情况下,以何种顺序向数据源发送通过 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));
经过简单的测试,并发冲突的问题貌似得到了解决