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交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- Access对子窗体数据进行批...(10.30)
- 最精简的组合框行来源数据快速输...(10.25)
- Access仿平台的多值选择器...(10.24)
- 【Access日期区间段查询】...(10.22)
- 【Access源码示例】VBA...(10.12)
- Access累乘示例,Acce...(10.09)
- 数值8.88,把整数8去掉,转...(10.08)
- 【Access自定义函数】一个...(09.30)
- 【Access选项卡示例】Ac...(09.09)
学习心得
最新文章
- Access快速开发平台企业版--...(11.18)
- 不会用多表联合查询,多表查询没结果...(11.16)
- 【案例分享】主键字段值含有不间断空...(11.16)
- Access快速开发平台--后台D...(11.14)
- 微软Access邀测新Monaco...(11.12)
- Access列表框左右互选、列表框...(11.11)
- 高效率在导入数据前删除记录(11.10)
- Access报价单转订单示例代码(11.08)
- Access系统自带的日期选择器不...(11.08)
- 分享一下Access工程中的acw...(11.07)