开发者

数据库触发器Trigger详解

目录
  • 触发器的三要素
  • 触发器的分类
  • 创建触发器
  • 行级触发器
  • 语句级触发器
  • 修改触发器
  • 删除触发器

在数据库管理系统中,触发器(Trigger)是一种特殊的存储过程,它在特定的事件发生时自动执行。触发器通常用于维护数据的完整性和一致性。通过事件触发而被执行,不编程客栈能直接调用。

触发器的三要素

触发事件 before/after(insert、update、delete)

触发条件 when

触发动作 begin ... end

触发器的分类

根据触发时机和触发事件的不同,触发器可以分为以下几种类型:行级触发器与语句级触发器

编程客栈级触发器(Row-Level Trigger)在每一行数据受到影响时触发,例如在插入、更新或删除某一行数据时。

语句级触发器(Statement-Level Trigger)则在执行一条SQL语句时触发,无论该语句影响了多少行数据。

创建触发器

SQL> creagte trigger <触发器名>  [{before | after}]
{[inster | delete | update of 列名列表] }
on 表名
[ referencing <临时视图名>]
[ when <触发条件>]
<触发动作>
end [触发器名]

说明:

update: 指明是update触发器,每当update语句修改由of子句指定的列时,激发触发器。如果忽略of子句,每当update修改表的任意列值时,都将激发触发器。

referencing <临时视图名>:指定临时视图别名,在触发器运行过程中,系统会生成另个临时视图分别存放被更新值旧值和新值(rollback用)。对于行级触发器,默认临时视图名分别为old和new;对于语句级触发器,默认临时视图名分别为old-table和new-table。

例如:

行级触发器

触发器中还可以回退修改使用rollback

SQL> create trigger bad_trg after update of balance on users
referencing new row as nrow, old row as orow
for each row
when nrow.balance < 0
begin
rollback
# 插入不良记录
insert into bads select concat(borrows.userid, convert(varchar(100), getdate(), 10)), borrows.userid, brid, getdate()  from borrows  when nrow.userid = borrows.userid and etime is null
end

语句级触发器

SQL> create trighttp://www.devze.comger RAISE_LIMIT after update of SAL on EMP
referencing new table as n_tb,  old table as o_tb
for each statement
when (800 > (select avg(SAL) from EMP)
begin
delete from EMP where ENO in ( select ENO from n_tb ) insert into EMP ( select * from o_tb )
end

修改触发器

SQL> alter  trigger bad_trg  after  update on users
AS
BEGIN
    -- 新的触发器逻辑
  编程客栈  PRINT 'Employee record has been upythonpdated.'
    -- 可以添加更多的逻辑,例如记录日志或执行其他操作
END

删除触发器

SQL> drop  trigger bad_trg

到此这篇关于数据库触发器Trigger的文章就介绍到这了,更多相关数据库触发器Trigger内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新数据库

数据库排行榜