设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 3444|回复: 5
打印 上一主题 下一主题

[模块/函数] Access中事务处理问题[已解决]

[复制链接]
跳转到指定楼层
1#
发表于 2008-3-6 09:15:39 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本人从其它网站下载了下面关于Access中事务处理的例子,但执行时在红色语句处提示编译错误,要求对象,不知道是否要先引用点什么?或者Access2000不支持事务回滚?

Public Sub BeginTransX()

   Dim cnn1 As ADODB.Connection
   Dim rstTitles As ADODB.Recordset
   Dim strCnn As String
   Dim strTitle As String
   Dim strMessage As String
   ' 打开连接。
   Set strcnn = currentproject.connection
   Set cnn1 = New ADODB.Connection
   cnn1.Open strCnn
   ' 打开 Titles 表。
   Set rstTitles = New ADODB.Recordset
   rstTitles.CursorType = adOpenDynamic
   rstTitles.LockType = adLockPessimistic
   rstTitles.Open "titles", cnn1, , , adCmdTable
   
   rstTitles.MoveFirst
    '开始事务
   cnn1.BeginTrans
   ' 在记录集中循环并询问是否想要更改指定标题的类型。
   Do Until rstTitles.EOF
      If Trim(rstTitles!Type) = "psychology" Then
         strTitle = rstTitles!Title
         strMessage = "Title: " & strTitle & vbCr & _
         "Change type to self help?"
         ' 更改指定雇员的标题。
         If MsgBox(strMessage, vbYesNo) = vbYes Then
            rstTitles!Type = "self_help"
            rstTitles.Update
         End If
      End If
         rstTitles.MoveNext
   Loop
   ' 询问用户是否想提交以上所做的全部更改。
   If MsgBox("Save all changes?", vbYesNo) = vbYes Then
      '如果回答是,就结束事务
      cnn1.CommitTrans
   Else
     '如果回答否,就回滚事务,取消所有操作
      cnn1.RollbackTrans
   End If
   rstTitles.Close
   cnn1.Close
End Sub

[ 本帖最后由 3828688 于 2008-3-19 14:47 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享分享 分享淘帖 订阅订阅

点击这里给我发消息

2#
发表于 2008-3-6 09:33:55 | 只看该作者
Set strcnn = currentproject.connection  这句语法错了

strCnn是字符串 而currentproject.connection  是连接
应该是
Set  cnn1= currentproject.connection
3#
发表于 2008-3-6 10:07:00 | 只看该作者
关注中.........
4#
 楼主| 发表于 2008-3-6 10:18:50 | 只看该作者
   将:
Set strcnn = currentproject.connection
   Set cnn1 = New ADODB.Connection
   cnn1.Open strCnn
1改为:
   Set cnn1 = currentproject.connection
   Set cnn1 = New ADODB.Connection
   cnn1.Open strCnn
2改为:
   Set cnn1 = New ADODB.Connection
   cnn1.Open currentproject.connection
都是不行

点击这里给我发消息

5#
发表于 2008-3-6 11:03:25 | 只看该作者
Set cnn1 = currentproject.connection
   ' Set cnn1 = New ADODB.Connection  '不需要
   ' cnn1.Open strCnn '不需要
6#
 楼主| 发表于 2008-3-6 11:16:09 | 只看该作者
问题解决,非常感谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-6 16:38 , Processed in 0.086625 second(s), 30 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表