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

如题所述

第1个回答  2022-12-11

解决办法如下:

--创建测试表

create table t_a(id int,name varchar(10));create table t_b(id int,name varchar(10));--测试数据insert into t_a(id,name) values (1,'a');--创建 for delete 触发器create trigger trg_t_a_1 on t_afor deleteasbegininsert into t_b select id,name from deleted;end--从t_a中删除一条数据delete from t_a where id=1;

--查看t_b
select * from t_b

触发器的作用:

触发器有如下作用:

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

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

    部分数据库管理系统可以针对数据定义语言(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 错误日志。如果身份验证失败,将不激发登录触发器。

相似回答