如何解决(VS 2017) WPF/MVVM如何回滚对项目集合的更改
我应该实现一个简单的过程来从映射到数据库的数据集合中删除一些项目(例如:车辆,ItemsDC 实体容器的一部分)
'DB Mapping
Public ItemsDC as ItemsDataContext
Sub DeleteVehicles()
Try
Dim qryV = From v In ItemsDC.Vehicles Where .... Select v
If qryV.Count > 0 Then
For Each vei In qryV
ItemsDC.Vehicles.DeleteObject(vei)
Next
End If
'Save changes to DB
ItemsDC.SaveChanges(SaveOptions.AcceptAllChangesAfterSave)
Catch ex As Exception
'rollback changes
RollbackAll()
End Try
End Sub
'RollbackAll,rebuilds collection from DB
Sub RollbackAll()
Dim CString As String = ConfigurationManager.ConnectionStrings("ItemsDataContext").ConnectionString
entityBuilder = New EntityConnectionStringBuilder(CString)
Dim sqlBuilder = New SqlConnectionStringBuilder(entityBuilder.ProviderConnectionString)
sqlBuilder.DataSource = DBName
sqlBuilder.UserID = AppUser
sqlBuilder.Password = AppPassword
entityBuilder.ProviderConnectionString = sqlBuilder.ConnectionString
ItemsDC = New RappCoaDataContext(entityBuilder.ConnectionString)
End Sub
我意识到 DeleteObject(vei) 似乎是立即提交的;因此,如果引发异常并执行 RollbackAll,则 Vehicles 集合丢失了一些项目。 如何正确回滚更改?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。