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, 陳格 保留所有權利