事件event

 event 是用来连接一个系统触发事件与响应这个触发事件的处理方法的.
通常event是一个指向类实例方法的方法指针;

事件也是一种属性, 因此一般定义如下:
FOnUpdateMinute: TNotifyEvent;
property OnUpdateMinute: TNotifyEvent read FOnUpdateMinute write OnUpdateMinute;
procedure OnUpdateMinute(const Value: TNotifyEvent);

TNotifyEvent 的定义:
type TNotifyEvent = procedure (Sender: TObject) of object; // 事件方法是一个过程

事件方法是可选的, 即必须提供默认的事件处理代码.


使用标准事件:
VCL组件继承了标准事件, 一般是 protected.

标准事件分为两类:
一种是所有控件(继承于TControl)共有的: 如鼠标事件, 键盘事件; 一般都有对应的回调方法:
OnClick--> Click; OnEndDrag--> DoEndDrag.
一种是标准控件(继承于TWinControl):
如: OnEnter, OnKeyDown, OnKeyPress, OnExit.
响应windows消息 WM_GETDLGCODE 或 CM_WANTSPECIALKEYS处理特殊按键(如Alt).

TControl 和 TWinControl中的标准事件一般定义在 Protected中.
从这两个类中继承的子类的事件需要在Public或published 中重新定义.

重写事件的处理方法: override, inherited;

自定义事件:
1. 触发事件 -- 什么情况下触发定义的事件; 鼠标,键盘,时间,状态改变等.
2. 事件方法类型:
 TNotifyEvent: 仅仅发出事件已经发生的通知, 不带有参数.
 特殊事件类型: 比如键盘事件就附加有按键信息; 消息事件通过消息参数传递信息;
 事件方法中返回信息: 因为所有的事件方法都是 procedure, 只有通过 var 参数来返回事件是否处理;
 OnKeyDown, OnKeyUp, and OnKeyPress 即传递 var key 参数.
3. 声明事件:
 事件一般以 On 前缀命名, 在通讯和数据库组件事件中也有 Before, After 前缀.
4. 调用事件:
   默认的事件处理代码;
   覆盖 override 默认的事件处理方法;


 

在 MySQL 中,可以通过 `DROP EVENT` 语句删除一个或多个已创建的事件event)。事件是存储在数据库中的一种对象,用于在指定的时间或间隔自动执行某些任务。删除事件的操作需要具有足够的权限,例如 `EVENT` 权限。 ### 删除事件的基本语法如下: ```sql DROP EVENT [IF EXISTS] event_name; ``` - `IF EXISTS` 是可选参数,用于防止在指定事件不存在时产生错误。如果事件不存在且未使用该参数,MySQL 将返回错误信息。 - `event_name` 是要删除的事件的名称。 例如,要删除名为 `daily_cleanup` 的事件,可以使用以下语句: ```sql DROP EVENT IF EXISTS daily_cleanup; ``` 此语句将从数据库中永久删除事件 `daily_cleanup`,并且无法恢复。执行该操作后,事件将不再出现在 `INFORMATION_SCHEMA.EVENTS` 表中[^1]。 ### 注意事项: 1. **权限要求**:用户必须具有对事件的 `ALTER` 或 `DROP` 权限,才能执行删除操作。 2. **事件调度器状态**:如果事件调度器(`event_scheduler`)被禁用,删除事件的操作仍然可以执行,因为该操作仅影响事件定义,而不影响其执行状态。 3. **依赖关系**:如果事件依赖于某些表、存储过程或其他数据库对象,删除事件不会影响这些对象本身。 ### 查看当前事件 在删除事件之前,可以通过以下语句查看当前数据库中存在的事件: ```sql SELECT * FROM information_schema.EVENTS; ``` 此查询将列出所有事件及其详细信息,包括事件名称、所属数据库、定义者、执行时间等。 ### 示例:删除事件并验证 ```sql -- 查看所有事件 SELECT EVENT_NAME, EVENT_SCHEMA, DEFINER FROM information_schema.EVENTS WHERE EVENT_SCHEMA = 'your_database'; -- 删除指定事件 DROP EVENT IF EXISTS your_database.your_event; -- 再次查询以确认事件是否已删除 SELECT EVENT_NAME, EVENT_SCHEMA, DEFINER FROM information_schema.EVENTS WHERE EVENT_SCHEMA = 'your_database'; ``` 通过上述步骤,可以确保事件被正确删除,并验证删除操作是否成功。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值