Access数据库培训
网站公告
·Access快速平台QQ群号:189307860    ·Access快速开发平台下载地址及教程    ·欢迎添加微信交流账号:Accessoft7    ·如何快速搜索本站文章|示例|资料!    
您的位置: 首页 > 技术文章 > Access数据库-教程

access开发平台新增,修改,删除,查找VBA代码详解\access开发平台代码解释\报销教程代码解释

时 间:2008-01-26 09:55:09
作 者:Access软件网编著   ID:8  城市:上海  QQ:2851379730点击这里给张志发消息
摘 要:Access开发平台新增,修改,删除,查找VBA代码详解
正 文:

以Access开发平台专业版报销教程中的报销明细的新增修改删除查找为例来详细说明下各代码的作用
以下代码是制作完成后的各个窗体的所有代码,具体哪一部分代码负责新增,哪一部分代码负责修改,可以在前面的教程中找到

首先是frmBxmx_child窗体,所有功能都做好以后窗体中的代码应该是如下所示:
Private Sub报销编号_GotFocus()                     -------机型代码获得焦点事件
On Error GoTo Err_报销编号_GotFocus:     -------错误处理语句,出错的时候转到Err_机型代码_GotFocus:执行
strSelectID = Me. 报销编号                               -------给变量赋值,使strselectID等于控件机型代码的值      
Forms!usysfrmMain!btnEdit.Tag = 999        -------这是个判断条件,当其大于1时点击"修改"按钮时,平台就会自动打开"_Edit"窗体
Forms!usysfrmMain!labFind.Tag = 1            -------同上,当其等于1时点击查询按钮时,打开平台内的查询窗体  
Exit_报销编号_GotFocus:       
    Exit Sub
Err_报销编号_GotFocus:
    Resume Exit_报销编号_GotFocus
End Sub
Private Sub Form_Timer()                                  ------窗体计时器事件
    Acchelp_FindStrRecord (g_CurrentSelectStrID)  ------利用平台函数acchelp_findstrrecord找到修改前鼠标所选择的记录
    '计时器执行一次后不再执行
    Me.TimerInterval = 0                                        ------设定刷新时间为0
End Sub
Public Sub btnDel()                                             ------删除代码
    If MsgBox("您确认要删除吗?", vbYesNo + vbInformation, Forms!usysfrmLogin.Caption) = vbYes Then -----判断提示框的值,当值为vbyes的时候执行下面代码,vbno的时候跳出代码
        DoCmd.Echo False                           ------防止屏幕闪动
        Call acchelp_deletefldstrrow("tblBxmx ", " mxId ", selectstr)         ------调用平台自定义函数AccHelp_DeleteFldStrRow,函数的详细说明请看平台帮助第九章
        Forms!usysfrmMain!frmChild.SourceObject = "frmBxmx_child" ------重新加载子窗体frmBxmx_child,以刷新数据子窗体数据
        DoCmd.Echo True           ------打开屏幕更新

    End If
End Sub
Public Sub btnFind()                   -------查询按钮单击事件
    DoCmd.OpenForm "usysfrmFind"   -------打开查询窗体
    '文本型对应 3 ,日期型对应 1 ,数值型对于 2      -------查询不同的字段类型的时候,对应不同的数字来表示
    Forms!usysfrmFind!cobfldName.RowSource = "报销日期;1;类别名称;3;员工姓名;3;报销金额;2;报销摘要;3;"   -------设置需要查询的字段,已经设定该查询字段的数据类型
    '指定查询数据来源
    Forms!usysfrmFind!labDataSource.Caption = "qryBxmx"
End Sub
Public Sub FindEnd()                            ----------------查询结束后执行的过程
    Forms!usysfrmMain!frmChild.Form.RecordSource = Acchelp_ChildFormRecordSource("qryBxmx", "报销编号", True)    -----------刷新子窗体数据,且为顺序排列查找后的数据(改成False即为降序排列)
    strRptReSource = Forms!usysfrmMain!frmChild.Form.RecordSource              ---------让定义的变量变量等于当前查询结束后子窗体的数据源
End Sub

以下是frmBxmx_child_add窗体的所有代码:
Private Sub cmd_Save()            --------------定义cmd_Save过程,执行数据新增
    Dim rst As DAO.Recordset      --------------定义DAO记录集
    If IsNull(Me.bxrq) Then       --------------判断报销日期是否为空,如果为空,则弹出对话框提示,下同
        MsgBox "请输入报销日期!", vbCritical, "提示:"
        Me.bxrq.SetFocus
        Exit Sub
    End If
    If IsNull(Me.lbId) Then
        MsgBox "请输入报销类别!", vbCritical, "提示:"
        Me.lbId.SetFocus
        Exit Sub
    End If
    If IsNull(Me.ygId) Then
        MsgBox "请输入员工姓名!", vbCritical, "提示:"
        Me.ygId.SetFocus
        Exit Sub
    End If
If IsNull(Me.bxje) Then
        MsgBox "请输入报销金额!", vbCritical, "提示:"
        Me.bxje.SetFocus
        Exit Sub
End If
Me.Refresh                  --------------数据输入完毕后刷新一下窗体控件
    If MsgBox("您确认要保存吗?", vbOKCancel + vbInformation, "提示") = vbOK Then      ------弹出对话框,询问用户是否需要保存数据,如果选择是,则执行以下代码
        Set rst = CurrentDb.OpenRecordset("tblBxmx", dbOpenDynaset)            ------设置记录集为表tblBxmx
        rst.AddNew            ---------开始新增数据
        rst("mxId") = acchelp_autoid("M", 10, "tblBxmx", "mxId")             ---------用平台函数设置编号字段
        rst("bxrq") = Me.bxrq          ---------让表中的bxrq字段等于当前窗体bxrq控件的值,下同
        rst("lbId") = Me.lbId
        rst("ygId") = Me.ygId
        rst("bxje") = Me.bxje
        rst("bxzy") = Me.bxzy
        rst.Update                                                     ----------新增完毕后更新一下记录集
        rst.Close            ----------关闭记录集
        Set rst = Nothing                                               ----------清空记录集
        '刷新数据
        If IsLoaded("usysfrmMain") Then
            DoCmd.Echo False
            Forms!usysfrmMain!frmChild.SourceObject = "frmBxmx_child"         --------------重新加载一下子窗体,以刷新数据
            DoCmd.Echo True                                       -----------------开启屏幕更新
        End If
        MsgBox "保存成功!", vbInformation, "提示"
        Me.bxrq = Null                                                     ---------------让窗体里的控件清空,下同
        Me.lbId = Null
        Me.ygId = Null
        Me.bxje = Null
        Me.bxzy = Null
    End If
End Sub
Private Sub cmdOK_Click()
    cmd_Save                                                           ------------单击确定按钮,执行cmd_Save过程
End Sub
Private Sub cmdCancel_Click()
    DoCmd.Close acForm, Me.Name                 -----------单击取消按钮关闭当前窗体
End Sub
Private Sub cmdBX_ButtonClick(ByVal Button As Object)
    DoCmd.OpenForm "frm_CodeBxlb_child_Add"          ----------打开报销类别新增窗体,用来快捷添加
End Sub
Private Sub cmdYG_ButtonClick(ByVal Button As Object)
    DoCmd.OpenForm "frmyg_child_Add"                        --------------打开员工信息新增窗体,快捷添加
End Sub

以下是修改窗体的代码:
Private Sub cmdCancel_Click()       -----------单击取消按钮事件
    Me.Undo          -----------撤销修改
    DoCmd.Close acForm, Me.Name     -----------关闭当前窗体
End Sub

Private Sub cmdOK_Click()       -----------单击确定按钮事件
    If IsNull(Me.bxrq) Then       -----------判断控件是否为空,如果为空则提示要求输入的信息
        MsgBox "请输入报销日期!", vbCritical, "提示:"
        Me.bxrq.SetFocus
        Exit Sub
    End If
    If IsNull(Me.lbId) Then
        MsgBox "请输入报销类别!", vbCritical, "提示:"
        Me.lbId.SetFocus
        Exit Sub
    End If
    If IsNull(Me.ygId) Then
        MsgBox "请输入员工姓名!", vbCritical, "提示:"
        Me.ygId.SetFocus
        Exit Sub
    End If
    If IsNull(Me.bxje) Then
        MsgBox "请输入报销金额!", vbCritical, "提示:"
        Me.bxje.SetFocus
        Exit Sub
    End If
    Me.Refresh         ------------刷新一下窗体
DoCmd.Echo False                                -----------------关掉屏幕更新
Forms!usysfrmMain!frmChild.SourceObject = "frmBxmx_child"         --------------修改完毕后刷新一下子窗体
    DoCmd.Echo True                              -----------------开启屏幕更新
    '触发子窗体计时器事件
    Forms!usysfrmMain!frmChild.Form.TimerInterval = 300
    DoCmd.Close acForm, Me.Name      ----------关闭当前窗体
End Sub

Private Sub Form_Load()
    Me.RecordSource = "Select * FROM tblBxmx Where mxId = '" & selectstr & "'"      ------------窗体加载事件,加载的时候设置窗体的数据源为后面的SQL语句所查询到的数据
End Sub
 

相关索引: 上一节  完



Access软件网QQ交流群 (群号:473665531)       access源码网店

最新评论 查看更多评论(8)

2013/6/21 13:56:23天马
总算学完!~ 受益匪浅! 就是没有导入的教程!~

2013/3/17 8:19:49fengfeng
写的真长,先顶再看

2012/7/26 22:57:28文科
终于学完了,受益匪浅啊,谢谢

2012/3/31 18:09:42杏林求真
谢谢,终于看完了。缺失不错。可惜导入的代码没有介绍。

2011/11/8 8:46:12西岭村人
非常感谢分享,但这种增加操作是不是只能针对一次增加一行记录的情况,要是有多行增加、修改、删除应该如何写呢?

发表评论您的评论将提升作者分享的动力!快来评论一下吧!

用户名:
密 码:
内 容:
 

常见问答

技术分类

相关资源

关于我们 | 服务条款 | 在线投稿 | 友情链接 | 网站统计 | 网站帮助