docmd.runsql 语句执行的操作查询如何回滚?
来源:互联网 发布:淘宝提前收款疯狂扣费 编辑:程序博客网 时间:2024/05/16 07:41
简述:
docmd.runsql 语句执行的操作查询如何回滚?
问题:
docmd.runsql 语句执行的操作查询如何回滚?
回答:
希望通过docmd.runsql实现事务的回滚(RollBack)操作
很遗憾的说,Access无法法通过docmd.runsql来实现事务的回觥4蠹乙残碜⒁獾皆贒ocmd.runsql的语句操作的帮助中,有一个选项是UseTransaction。这个选项的是用来确认是否对该语句进行事务性的操作。如果选择True(默认为True),那么所有的操作都将被当作是一个单独的原子操作来对数据库进行操作;如果选择是False,那么操作将不会被当作事务(在多用户的情况下可能会出现Dirty Read)的情况。但是这些事务都是在内部完成的,我们无法显示的通过申明commit或者rollback来控制其操作。
根据我的经验,ACCESS也无法通过docmd.OPENQUERY来完成类似的事务显示操作。如果大家希望实现事务的操作,唯一的用法就是通过WorkSpaceObject.BeginTrans来实现。在Access VBA的帮助文件中,大家可以找到如下的示例:
'BeginBeginTransVB
'To integrate this code
'replace the data source and initial catalog values
'in the connection string
Public Sub Main()
On Error GoTo ErrorHandler
'recordset and connection variables
Dim Cnxn As ADODB.Connection
Dim strCnxn As String
Dim rstTitles As ADODB.Recordset
Dim strSQLTitles As String
'record variables
Dim strTitle As String
Dim strMessage As String
' Open connection
strCnxn = "Provider='sqloledb';Data Source='MySqlServer';" & _
"Initial Catalog='Pubs';Integrated Security='SSPI';"
Set Cnxn = New ADODB.Connection
Cnxn.Open strCnxn
' Open recordset dynamic to allow for changes
Set rstTitles = New ADODB.Recordset
strSQLTitles = "Titles"
rstTitles.Open strSQLTitles, Cnxn, adOpenDynamic, adLockPessimistic, adCmdTable
Cnxn.BeginTrans
' Loop through recordset and prompt user
' to change the type for a specified title
rstTitles.MoveFirst
Do Until rstTitles.EOF
If Trim(rstTitles!Type) = "psychology" Then
strTitle = rstTitles!Title
strMessage = "Title: " & strTitle & vbCr & _
"Change type to self help?"
' If yes, change type for the specified title
If MsgBox(strMessage, vbYesNo) = vbYes Then
rstTitles!Type = "self_help"
rstTitles.Update
End If
End If
rstTitles.MoveNext
Loop
' Prompt user to commit all changes made
If MsgBox("Save all changes?", vbYesNo) = vbYes Then
Cnxn.CommitTrans
Else
Cnxn.RollbackTrans
End If
' Print recordset
rstTitles.Requery
rstTitles.MoveFirst
Do While Not rstTitles.EOF
Debug.Print rstTitles!Title & " - " & rstTitles!Type
rstTitles.MoveNext
Loop
' Restore original data as this is a demo
rstTitles.MoveFirst
Do Until rstTitles.EOF
If Trim(rstTitles!Type) = "self_help" Then
rstTitles!Type = "psychology"
rstTitles.Update
End If
rstTitles.MoveNext
Loop
' clean up
rstTitles.Close
Cnxn.Close
Set rstTitles = Nothing
Set Cnxn = Nothing
Exit Sub
ErrorHandler:
' clean up
If Not rstTitles Is Nothing Then
If rstTitles.State = adStateOpen Then rstTitles.Close
End If
Set rstTitles = Nothing
If Not Cnxn Is Nothing Then
If Cnxn.State = adStateOpen Then Cnxn.Close
End If
Set Cnxn = Nothing
If Err <> 0 Then
MsgBox Err.Source & "-->" & Err.Description, , "Error"
End If
End Sub
'EndBeginTransVB
最后,强烈推荐大家阅读下列文档,在文档有一个章节:Transactions在Access中的用法和定义
Advanced Microsoft Jet SQL for Access 2000
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnacc2k/html/acadvsql.asp
另外,请参考本站的文章:
关于事务处理
http://access911.net/index.asp?u1=a&u2=73FABF1E14DC
什么是事务处理?怎么进行事务处理?
http://access911.net/index.asp?u1=a&u2=71FABE1E13DC
- docmd.runsql 语句执行的操作查询如何回滚?
- docmd.runsql语句执行的操作查询如何回滚?
- docmd.runsql 语句执行的操作查询如何回滚?
- 如何禁止/屏蔽docmd.runsql执行查询时的提示?
- ADO, DAO, DoCmd.RunSQL 三种方式用哪一种?
- mssqlserver - 查询执行的错误信息以及事务回滚
- 如何操作git回滚
- 如何查询mysql中执行效率低的sql语句
- JAVA中处理事务的程序--多条更新SQL语句的执行(包括回滚) .
- JAVA中处理事务的程序--多条更新SQL语句的执行(包括回滚)
- JAVA中处理事务的程序--多条更新SQL语句的执行(包括回滚)
- Vb Ado实现带事务回滚的sql语句执行
- 利用预备语句执行查询操作
- 查询语句的执行顺序
- 甲骨文语句级别的回滚
- Mysql 不能回滚的语句
- 如何在存储执行中,查询某条sql语句的执行计划。
- 认识Oracle的回滚操作后对查询的影响
- 长命百岁和死而复生
- 如何将EXP出来的数据IMP进不同的表空间
- OracleDBA讲座笔记2--- oracle运行环境准备
- 介绍Matisse--专为.NET的后关系型数据库part 1
- 使用product_user_profile来实现用户权限的设定
- docmd.runsql 语句执行的操作查询如何回滚?
- 怎样将Excel中的数据导入到SQL Server 2000数据库中
- NULL及DUAL详解
- 查看和监控数据库
- 建立数据库链接
- 位图菜单的制作
- 快速转移数据的方法
- 使用sql*loader进行数据导入
- SQL SERVER2000数据库备份和恢复存储过程(加强版本)