Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/jpa/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
(VS 2017)WPF/MVVM。如何回滚对项目集合的更改_Mvvm_Datacontext_Rollback - Fatal编程技术网

(VS 2017)WPF/MVVM。如何回滚对项目集合的更改

(VS 2017)WPF/MVVM。如何回滚对项目集合的更改,mvvm,datacontext,rollback,Mvvm,Datacontext,Rollback,我应该实现一个简单的过程,从映射到DB的数据收集中删除一些项(例如:车辆,ItemsDC实体容器的一部分) 我意识到DeleteObject(vei)似乎是立即提交的;所以,若引发异常并执行RollbackAll,则Vehicles集合已丢失一些项。 如何正确回滚更改 'DB Mapping Public ItemsDC as ItemsDataContext Sub DeleteVehicles() Try Dim qryV = From v In ItemsDC.Vehicle

我应该实现一个简单的过程,从映射到DB的数据收集中删除一些项(例如:车辆,ItemsDC实体容器的一部分)

我意识到DeleteObject(vei)似乎是立即提交的;所以,若引发异常并执行RollbackAll,则Vehicles集合已丢失一些项。 如何正确回滚更改

'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