mysql中触发器 删除表数据_如何定义一个触发器,当删除表中数据时,先将删除的数据插入到另一个表中,然后执行删除操作?...

可在写入数据表前,强制检验或转换数据。

触发器发生错误时,异动的结果会被撤销。

部分数据库管理系统可以针对数据定义语言(DDL)使用触发器,称为DDL触发器。

可依照特定的情况,替换异动的指令 (INSTEAD OF)。

分类

[2]  SQL Server 包括三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。

DML触发器

当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行。DML触发器的主要作用在于强制执行业 务规则,以及扩展Sql Server约束,默认值等。因为我们知道约束只能约束同一个表中的数据,而触发器中则可以执行任意Sql命令。

DDL触发器

它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的操作。比如在修改表,修改列,新增表,新增列等。它在数据库结构发生变化时执行,我们主要用它来记录数据库的修改过程,以及限制程序员对数据库的修改,比如不允许删除某些指定表等。

登录触发器

登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用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表中。 需要注意的是,当使用触发器,需要确保数据库的性能不会受到影响。如果数据量很大,可能需要使用其他技术来处理数据同步。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值