一种适合新手理解的解决数据绑定窗体关闭时不保存修改数据的方法
时 间:2019-11-03 08:01:25
作 者:朱朱 ID:8813 城市:上海
摘 要:本文介绍了一种适合新手理解的解决数据绑定窗体关闭时不保存修改数据的方法。
正 文:
Access的窗体如果绑定数据的话,则对记录的增与改都是相当方便的。一般来说一个这样的窗体通常会新增数据与编辑数据共用,其采用动态集绑定某张数据表。但这里也有一个问题,无论新增还是编辑了某条记录,如果已经修改了一定的数据中途想放弃新增或者编辑的话,关闭窗体后,Access还是会将数据保存到表中,这显然不是我们想得到的结果。
通过进一步的窗体的学习可以知道,Access窗体有个Dirty事件,通过对Dirty进行判断可以达到在窗体关闭时对已经编辑的数据不保存。不过这个Dirty对于新手来说,理解起来可能有一点点不太友好。本文就尝试用一种较易理解的方式来解决这个问题。本文采用的示例是Access软件网职场范例中的一个示例,稍稍作了一定的修改。
首先在编辑窗体(frm供应商资料_Edit)代码中定义一个变量:Dim bSaveFlag As Boolean,注意变量的位置,具体可以看示例。
附 件:
在窗体的Load事件中,先将其值设置成False
Private Sub Form_Load()
bSaveFlag = False
End Sub
在保存按钮里面,DoCmd.RunCommand acCmdSave这句代码前设置其值为Ture
bSaveFlag = True
DoCmd.RunCommand acCmdSave
最后是在窗体的BeforeUpdate事件中进行判断
Private Sub Form_BeforeUpdate(Cancel As Integer)
If bSaveFlag = False Then
Cancel = True
End If
End Sub
这样之后,无论新增还是编辑,如果中途想放弃,关闭窗体后就都不会保存数据了。
现在来讲解一下实现的原理。定义这个变量之后,在窗体的Load事件中先将其设为False,如果确实要保存数据,点击了保存按钮,则其值再设置为True,则可以正常保存数据。 如果修改了部分数据,中途想要关闭窗体,则都会触发窗体的BeforeUpdate事件,那么就可以在这个事件中进行判断,如果bSaveFlag为False则表示不希望保存数据,则设置参数Cancel为Ture,这样修改的数据就不会被保存了。这样也就达到了修改了记录但关闭窗体不保存的目的。
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)