mysql详解9:触发器和事件
2021/7/30 19:36:08
本文主要是介绍mysql详解9:触发器和事件,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
触发器是在插入 更新 删除语句前后自动执行的sql代码
保证数据一致性
DELIMITER $$
CREATE TRIGGER payment_after_insert
After INSERT ON payments
for EACH row
BEGIN
UPDATE invoices
set payment_total payment_total+NEW.amout
where invoice_id =NEW.invoice_id;
END $$
NEW 返回新增的行
OLD 在更新和删除时候用 返回更新前的行 及对应数值
DELIMITER $$
CREATE TRIGGER payments_after_delete
AFTER DELETE ON payments
FOR EACH ROW
BEGIN
UPDATE invoices
set payment_total =payment_total-OLD.amount
where invoice_id =OLD.invoice_id;
END $$
DELITER;
查看触发器
show TRIGGER 显示所有的触发器
show TRIGGER LIKE 'payments%'
删除触发器
DROP TRIGGER IF EXISTS payment_after_insert
使用触发器进行审计
操作记录
DELIMITER $$
DROP TRIGGER IF EXISTS payments_after_delete
CREATE TRIGGER payments_after_delete
AFTER DELETE ON payments
FOR EACH ROW
BEGIN
UPDATE invoices
set payment_total =payment_total-OLD.amount
where invoice_id =OLD.invoice_id;
INSERT INTO payment_audit
values (OLD.client_id,OLD.date,OLD.amount,'delete',NOW());
END $$
DELITER;
事件是根据计划执行的任务或一堆sql代码 定时任务
show variables like 'event%';
set global event_scheduler=on;
--定义一个定时任务
DELIMITER $$
CREATE EVENT hourly_update_member
on SCHEDULE
-- at "2021-07-30"
EVERY 1 hour STARTS '2021-01-01' ENDS '2021-12-31'
do begin
update member set sex=sex+1
where `year` < now() - INTERVAL 1 year;
-- 超过一年的记录
end $$
DELIMITER;
SHOW EVENTS;
DROP EVENT IF EXISTS hourly_update_member;
alter 和 create 的语法相同
ALTER EVENT hourly_update_member DISABLE;//ENABLE 事件可以暂时启用禁用
这篇关于mysql详解9:触发器和事件的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-02MySQL 3主集群搭建
- 2024-12-25如何部署MySQL集群资料:新手入门教程
- 2024-12-24MySQL集群部署资料:新手入门教程
- 2024-12-24MySQL集群资料详解:新手入门教程
- 2024-12-24MySQL集群部署入门教程
- 2024-12-24部署MySQL集群学习:新手入门教程
- 2024-12-24部署MySQL集群入门:一步一步搭建指南
- 2024-12-07MySQL读写分离入门:轻松掌握数据库读写分离技术
- 2024-12-07MySQL读写分离入门教程
- 2024-12-07MySQL分库分表入门详解