(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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...