并发冲突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));
经过简单的测试,并发冲突的问题貌似得到了解决
在许多情况下,以何种顺序向数据源发送通过 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));
经过简单的测试,并发冲突的问题貌似得到了解决
- 并发冲突UpdateCommand影响0个记录”的错误
- 关于“违反并发性: UpdateCommand影响了预期 1 条记录中的 0 条”的数据库更新错误
- (违反并发性: UpdateCommand 影响了预期 1 条记录中的 0 条 )的原因
- 违反并发性: UpdateCommand影响了预期 1 条记录中的 0 条
- 违反并发性: UpdateCommand影响了预期 1 条记录中的 0 条
- 违反并发性: UpdateCommand影响了预期 1 条记录中的 0 条
- 违反并发性: UpdateCommand 影响了预期1条记录中的0条
- 违反并发性: UpdateCommand影响了预期 1 条记录中的 0 条
- 构造SqlDataAdapter InsertCommand和UpdateCommand 帮助类解决并发冲突
- 解决问题:Concurrency violation: the UpdateCommand affected 0 of the expected 1 records(UpdateCommand 影响了预期1 条记录中的0 条 )
- 不支持 UpdateCommand 的动态 SQL 生成”错误“
- 调用《构造SqlDataAdapter InsertCommand和UpdateCommand 帮助类解决并发冲突》方法
- 如何避免影响SharePoint性能的5个错误
- 7个影响数据分析的数据建模错误
- [学习笔记][ASP.NET2.0][Gridview][UpdateCommand的写法要点]
- Gridview][UpdateCommand的写法要点]
- 并发影响
- 并发冲突
- 集成的 IaaS 解决方案
- 10个非常有用的PHP代码片段
- java.lang.OutOfMemoryError: bitmap size exceeds VM budget解决方法
- UIView属性clipsTobounds的应用
- 从零开始学习OpenGL ES之六 – 纹理及纹理映射
- 并发冲突UpdateCommand影响0个记录”的错误
- android Spinner(下拉菜单)的应用举例1---静态实现
- Android 1.5 1.6 2.0 2.1 2.2 2.3 3.0的区别 (转载)
- ViewStub的应用
- viewWillAppear: viewDidAppear: viewWillDisappear:viewDidDisappear:loadView; 使用时的区别
- 从零开始学习OpenGL ES之五补遗 – setupView重写
- 身边人,最好的名片
- c++中常函数的应用举例
- BPM与SOA之间的区别及联系