SQL练习41:构造一个触发器audit_log,在向employees表中插入一条数据的时候,触发插入相关的数据到audit中

SQL练习41:构造一个触发器audit_log,在向employees表中插入一条数据的时候,触发插入相关的数据到audit中

题目链接:牛客网

题目描述
构造一个触发器audit_log,在向employees_test表中插入一条数据的时候,触发插入相关的数据到audit中。

CREATE TABLE employees_test(
ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL
);
CREATE TABLE audit(
EMP_no INT NOT NULL,
NAME TEXT NOT NULL
);

解法

CREATE TRIGGER audit_log AFTER INSERT ON employees_test FOR EACH ROW
BEGIN
    INSERT INTO audit VALUES (NEW.ID, NEW.NAME);
END;

触发器
监视某种情况,并触发某种操作,它是提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,例如当对一个表进行操作( insert,delete, update)时就会激活它执行。

至于触发器的貌似很多人都不太愿意使用,更愿意使用存储过程,原因如下:
存储过程需要显式调用,阅读源码的时候你能知道存储过程的存在,而触发器必须在数据库端才能看到,容易被忽略。


为什么大家都不推荐使用MySQL触发器而用存储过程?

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
可以使用MySQL触发器来实现当一个表发生插入或更新时,将数据同步到另一张表中的功能。触发器是在执行INSERT、UPDATE或DELETE语句时自动执行的一段程序。以下是一个简单的例子: 假设我们有两个表,一个employees表,另一个employee_audit表。当employees表发生插入或更新时,我们需要将数据同步到employee_audit表中。 首先,我们需要在employee_audit表中创建一个employees表同的结构。然后,我们可以使用以下代码创建一个触发器: ``` CREATE TRIGGER sync_employee_audit AFTER INSERT ON employees FOR EACH ROW BEGIN INSERT INTO employee_audit (employee_id, name, age, salary) VALUES (NEW.employee_id, NEW.name, NEW.age, NEW.salary); END; ``` 这个触发器会在employees表中插入一行数据时自动执行。它会将插入数据同步到employee_audit表中。 同样,我们可以创建一个类似的触发器来处理employees表的更新操作: ``` CREATE TRIGGER sync_employee_audit AFTER UPDATE ON employees FOR EACH ROW BEGIN UPDATE employee_audit SET name = NEW.name, age = NEW.age, salary = NEW.salary WHERE employee_id = OLD.employee_id; END; ``` 这个触发器会在employees表中更新一行数据时自动执行。它会将更新的数据同步到employee_audit表中。 需要注意的是,当使用触发器时,需要确保数据库的性能不会受到影响。如果数据量很大,可能需要使用其他技术来处理数据同步。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dream丶Killer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值