Delphi”程序级触发器”功能的实现
2008-04-09 04:18:22来源:互联网 阅读 ()
以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://假设的一连锁更新相关表数据的过程
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Delphi5优化
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash