SQL实时任务调度核心靠数据库原生事件(定时执行)和触发器(数据变动即响应),二者配合覆盖多数场景:事件需开启event_scheduler,支持EVERY/STARTS/ENDS;触发器分BEFORE/AFTER,通过NEW/OLD访问数据;组合应用如触发器写缓存、事件批量处理;需注意权限、性能与稳定性。

SQL实时任务调度不靠外部脚本,核心是用好数据库原生的事件(Event)和触发器(Trigger)两类机制。事件解决“定时执行”,触发器解决“数据一变就响应”,两者分工明确,配合使用才能覆盖大多数实时场景。
MySQL事件:精准到秒的定时动作
MySQL事件调度器(event_scheduler)必须先开启,否则所有事件都不生效。检查命令:
SHOW VARIABLES LIKE 'event_scheduler';
返回 ON 才算启用成功。临时开启用:
SET GLOBAL event_scheduler = ON;
永久生效需在 my.cnf 里加 event_scheduler=ON 并重启服务。
创建一个每5分钟清理一次日志表的事件示例:
- 语法结构清晰:EVENT 名称 + ONSCHEDULE 定义时间 + DO 包裹实际操作
- 时间表达灵活:可用 EVERY 5 MINUTE,也可加 STARTS 和 ENDS 控制生命周期
- DO 块中支持多条语句,但不能有 SELECT 返回结果集(可改用 INSERT ... SELECT 或写入日志表)
- 事件默认启用,如需暂停可加 DISABLE 关键字
触发器:数据变动即刻响应
触发器不是定时运行,而是绑定在表的 DML 操作上,只要 INSERT/UPDATE/DELETE 发生,立刻触发。它没有时间概念,只认“事件发生”。
关键细节:
标签: mysql
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~