科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件Delphi”程序级触发器”功能的实现

Delphi”程序级触发器”功能的实现

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

在Delphi的数据集控件中,提供了类似关系数据库管理系统中触发器功能的事件机制----”触发器类”事件。灵活使用数据集控件的此类事件......

作者:陈立平 来源:yesky 2007年11月1日

关键字: Delphi 程序级 触发器 实现

  • 评论
  • 分享微博
  • 分享邮件
在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://假设的一连锁更新相关表数据的过程
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章