Chinaunix首页 | 论坛 | 博客
  • 博客访问: 16496233
  • 博文数量: 5645
  • 博客积分: 9880
  • 博客等级: 中将
  • 技术积分: 68081
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-28 13:35
文章分类

全部博文(5645)

文章存档

2008年(5645)

我的朋友

分类:

2008-04-28 20:49:10

下载本文示例代码
  在Delphi的数据集控件中,提供了类似关系数据库管理系统中触发器功能的事件机制----"触发器类"事件。灵活使用数据集控件的此类事件,能够实现"程序级的触发器"功能,以加强数据的完整性检验。  以Delphi中表数据集为例,其相应的"触发器类"事件:  事件名称 说明  BeforeInsert, AfterInsert 插入记录前后调用的事件  BeforeEdit, AfterEdit 编辑前后调用的事件  BeforePost, AfterPost 保存数据前后调用的事件  BeforeDelete, AfterDelete 删除前后调用的事件  BeforeCancel, AfterCancel 取消编辑前后调用的事件  BeforeOpen, AfterOpen 打开数据集前后调用的事件  BeforeClose, AfterClose 关闭数据集前后调用的事件  OnNewRecord 新记录产生时调用的事件  OnCalcField 当计算字段被计算时调用的事件  OnFilterRecord 启动过滤后,数据集内每条记录都调用此事件  事件使用举例:  1. 更改Delphi中DbNavigator控件默认的删除对话框  设置DbNavigator的ConfirmDelete属性为False,在Table控件的BeforeDelete事件中编写如下代码:  if Application.MessageBox('确实要删除当前记录吗?', '删除 确认', mb_YesNo mb_IconWarning)                <> Id_Yes then   Abort; file://利用哑异常阻止删除事件发生  2.在记录保存前检验数据的完整性,以及连锁更新相关表中的数据,实现数据完整性检验可通过表数据集控件的BeforePost事件检验:  file://GetNowCardMount为自定义函数(举例),假设其取得当前凭证的实际库存量  if Table1.FieldByName('OutCardMount').AsInteger > GetNowCardMount then    Application.MessageBox('当前输入凭证的下发数量超过该种凭证的实际库存量!', '错误', Mb_Ok                 Mb_IconError);   Abort; file://利用哑异常阻止数据保存,从而,使光标仍停留在当前行继续编辑  else file://如果需要连锁更新的话   UpdateProc; file://假设的一连锁更新相关表数据的过程共2页。 1 2 8 :   在Delphi的数据集控件中,提供了类似关系数据库管理系统中触发器功能的事件机制----"触发器类"事件。灵活使用数据集控件的此类事件,能够实现"程序级的触发器"功能,以加强数据的完整性检验。  以Delphi中表数据集为例,其相应的"触发器类"事件:  事件名称 说明  BeforeInsert, AfterInsert 插入记录前后调用的事件  BeforeEdit, AfterEdit 编辑前后调用的事件  BeforePost, AfterPost 保存数据前后调用的事件  BeforeDelete, AfterDelete 删除前后调用的事件  BeforeCancel, AfterCancel 取消编辑前后调用的事件  BeforeOpen, AfterOpen 打开数据集前后调用的事件  BeforeClose, AfterClose 关闭数据集前后调用的事件  OnNewRecord 新记录产生时调用的事件  OnCalcField 当计算字段被计算时调用的事件  OnFilterRecord 启动过滤后,数据集内每条记录都调用此事件  事件使用举例:  1. 更改Delphi中DbNavigator控件默认的删除对话框  设置DbNavigator的ConfirmDelete属性为False,在Table控件的BeforeDelete事件中编写如下代码:  if Application.MessageBox('确实要删除当前记录吗?', '删除 确认', mb_YesNo mb_IconWarning)                <> Id_Yes then   Abort; file://利用哑异常阻止删除事件发生  2.在记录保存前检验数据的完整性,以及连锁更新相关表中的数据,实现数据完整性检验可通过表数据集控件的BeforePost事件检验:  file://GetNowCardMount为自定义函数(举例),假设其取得当前凭证的实际库存量  if Table1.FieldByName('OutCardMount').AsInteger > GetNowCardMount then    Application.MessageBox('当前输入凭证的下发数量超过该种凭证的实际库存量!', '错误', Mb_Ok                 Mb_IconError);   Abort; file://利用哑异常阻止数据保存,从而,使光标仍停留在当前行继续编辑  else file://如果需要连锁更新的话   UpdateProc; file://假设的一连锁更新相关表数据的过程共2页。 1 2 8 : 下载本文示例代码


Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现Delphi”程序级触发器”功能的实现
阅读(143) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~