问题描述
我应该实现一个简单的过程来从映射到数据库的数据集合中删除一些项目(例如:车辆,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 (将#修改为@)