Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 窗体  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701898
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

运行时错误:3426,该操作被关联对象取消。注意事件的先后顺序及Cancel后的后果

作者:cg1  摘自:access911.net  :cg1  更新日期:2008-7-30  浏览人次:

 

问题:

运行时错误:3426,该操作被关联对象取消

一个窗体,希望在修改完后有个提示,如果点击确定,程序没有问题,如果点击否,程序会出现问题。问题记录如下:“运行时错误:3426,该操作被关联对象取消”

Private Sub Form_BeforeUpdate(Cancel As Integer)
    If MsgBox("该生的学历记录已被修改,是否要保存?", vbDefaultButton2 + vbNoYes) = vbNoThen
        Cancel = True
    End If
End Sub


Private Sub 学号_AfterUpdate()
    Dim rs As Dao.Recordset
    Set rs = Me.Recordset
    rs.FindFirst "[学号] = '" & Me![学号] & "'"     
    '上面这行代码出错,提示为:“运行时错误:3426,该操作被关联对象取消”
    Me.Bookmark = rs.Bookmark    
End Sub


 

回答:


学号是一个COMBO,选择学号后,整个窗体的记录跳转到另一条记录。问题就出现在跳转记录后  rs.FindFirst 会触发 Form_BeforeUpdate ,而如果 Form_BeforeUpdate 被 Cancel = true 后,系统不会自动取消 rs.FindFirst 方法,而只是抛出一个取消的错误。

应该在 rs.FindFirst 所在的行做好错误捕捉,一旦遇到错误先告知用户,不再进行跳转操作。


Private Sub 学号_AfterUpdate()
    Dim rs As Dao.Recordset
On Error Goto 学号_AfterUpdate_Err
    Set rs = Me.Recordset
    rs.FindFirst "[学号] = '" & Me![学号] & "'"     
    '上面这行代码出错,提示为:“运行时错误:3426,该操作被关联对象取消”
    Me.Bookmark = rs.Bookmark    


    exit sub
学号_AfterUpdate_Err:
    select case err.number
    case 3426
        msgbox "您取消了保存记录,因此无法进行记录跳转,请先保存或者按 Esc 键取消本条记录的修改然后再选择其他记录进行编辑"
    case else
        msgbox err.number & err.description
    end select

End Sub


 


本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利