编写名为update_trigger的触发器,当修改DEPT表中的DEPTNO时,EMP表中相应的字段的值也做修改。
CREATE OR REPLACE TRIGGER update_trigger
after update ON DEPT
for each row
begin
if newcontract_no <>:old.contract_no THEN
update EMP set DEPTNO =:new.contract_no where DEPTNO =:old.contract_no
end if
end
扩展资料:
DML触发器
当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行。DML触发器的主要作用在于强制执行业 务规则,以及扩展Sql Server约束,默认值等。因为我们知道约束只能约束同一个表中的数据,而触发器中则可以执行任意Sql命令。
DDL触发器
它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的操作。比如在修改表,修改列,新增表,新增列等。它在数据库结构发生变化时执行,我们主要用它来记录数据库的修改过程,以及限制程序员对数据库的修改,比如不允许删除某些指定表等。
登录触发器
登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。
参考资料来源:百度百科-触发器
2023-12-06 广告
after update ON DEPT
for each row
begin
if :new.contract_no <>:old.contract_no THEN
update EMP set DEPTNO =:new.contract_no where DEPTNO =:old.contract_no ;
end if;
end;
after
update of deptno on dept
for each row
begin
update emp set deptno=:new.deptno where deptno=:old.deptno;
end;