触发器的作用
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
触发器的作⽤
触发器
触发器(trigger)是个特殊的存储过程,它的执⾏不是由程序调⽤,也不是⼿⼯启动,⽽是由个事件来触发,⽐如当对⼀个表进⾏操作(insert,delete, update)时就会激活它执⾏。
触发器经常⽤于加强数据的完整性约束和业务规则等。
触发器可以从 DBA_TRIGGERS
,USER_TRIGGERS 数据字典中查到。
触发器可以查询其他表,⽽且可以包含复杂的 SQL 语句。
它们主要⽤于强制服从复杂的业务规则或要求。
例如,您可以根据客户当前的帐户状态,控制是否允许插⼊新订单。
触发器也可⽤于强制引⽤完整性,以便在多个表中添加、更新或删除⾏时,保留在这些表之间所定义的关系。
然⽽,强制引⽤完整性的最好⽅法是在相关表中定义主键和外键约束。
如果使⽤数据库关系图,则可以在表之间创建关系以⾃动创建外键约束。
⼀触发器介绍
触发器是⼀种特殊的存储过程,它在插⼊,删除或修改特定表中的数据时触发执⾏,它⽐数据库本⾝标准的功能有更精细和更复杂的数据控制能⼒。
数据库触发器有以下的作⽤:
* 安全性。
可以基于数据库的值使⽤户具有操作数据库的某种权利。
# 可以基于时间限制⽤户的操作,例如不允许下班后和节假⽇修改数据库数据。
# 可以基于数据库中的数据限制⽤户的操作,例如不允许股票的价格的升幅⼀次超过10%。
* 审计。
可以跟踪⽤户对数据库的操作。
# 审计⽤户操作数据库的语句。
# 把⽤户对数据库的更新写⼊审计表。
* 实现复杂的数据完整性规则。
# 实现⾮标准的数据完整性检查和约束。
触发器可产⽣⽐规则更为复杂的限制。
与规则不同,触发器可以引⽤列或数据库对象。
例如,触发器可回退任何企图吃进超过⾃⼰保证⾦的期货。
# 提供可变的缺省值。
* 实现复杂的⾮标准的数据库相关完整性规则。
触发器可以对数据库中相关的表进⾏连环更新。
例如,在auths表author_code列上的删除触发器可导致相应删除在其它表中的与之匹配的⾏。
# 在修改或删除时级联修改或删除其它表中的与之匹配的⾏。
# 在修改或删除时把其它表中的与之匹配的⾏设成NULL值。
# 在修改或删除时把其它表中的与之匹配的⾏级联设成缺省值。
# 触发器能够拒绝或回退那些破坏相关完整性的变化,取消试图进⾏数据更新的事务。
当插⼊⼀个与其主健不匹配的外部键时,这种触发器会起作⽤。
例如,可以在books.author_code
列上⽣成⼀个插⼊触发器,如果新值与auths.author_code列中的某值不匹配时,插⼊被回退。
* 同步实时地复制表中的数据。
* ⾃动计算数据值,如果数据的值达到了⼀定的要求,则进⾏特定的处理。
例如,如果公司的帐号上的资⾦低于5万元则⽴即给财务⼈员发送警告数据。
ORACLE与SYBASE数据库的触发器有⼀定的区别,下⾯将分别讲述这两种数据库触发器的作⽤和写法。
⼆ ORACLE 触发器
ORACLE产⽣数据库触发器的语法为:
create [or replace] trigger 触发器名触发时间触发事件
on 表名
[for each row]
pl/sql 语句
其中:
触发器名:触发器对象的名称。
由于触发器是数据库⾃动执⾏的,因此该名称只是⼀个名称,没有实质的⽤途。
触发时间:指明触发器何时执⾏,该值可取:
before---表⽰在数据库动作之前触发器执⾏;
after---表⽰在数据库动作之后出发器执⾏。
触发事件:指明哪些数据库动作会触发此触发器:
insert:数据库插⼊会触发此触发器;
update:数据库修改会触发此触发器;
delete:数据库删除会触发此触发器。
表名:数据库触发器所在的表。
for each row:对表的每⼀⾏触发器执⾏⼀次。
如果没有这⼀选项,则只对整个表执⾏⼀次。
举例:下⾯的触发器在更新表auths之前触发,⽬的是不允许在周末修改表:
create trigger auth_secure
before insert or update or delete file://对整表更新前触发
on auths
begin
if(to_char(sysdate,'DY')='SUN'
RAISE_APPLICATION_ERROR(-20600,'不能在周末修改表auths');
end if;
end
三 SYBASE数据库触发器
SYBASE数据库触发器的作⽤与ORACLE⾮常类似,仅有较⼩的差异。
SYBASE产⽣触发器的语法为:
CREATE TRIGGER 触发器名
ON 表名
FOR INSERT,UPDATE,DELETE
AS
SQL_statement |
FOR INSERT,UPDATE
AS
IF UPDATE(column_name) [AND|OR UPDATE(column_name)]...
SQL_statements
上⾯FOR⼦句⽤来指定在触发器上的哪些数据更新命令可激活该触发器。
IF UPDATE⼦句检查对指定列的操作类型,在IF UPDATE⼦句中可指定多个列。
与ORACLE不同,对于每条SQL语句,触发器只执⾏⼀次。
触发器在数据更新语句完成以后⽴即执⾏。
触发器和启动它的语句被当作⼀个事务处理,事务可以在触发器中回退。
下⾯举例说明SYBASE触发器的写法。
create trigger forinsert_books
on books
for insert
as
if(select count(*) from auths,inserted
where auths.author_code=insert.author_code)!=@@rowcount
begin
rollback transaction
print "books 表中 author_code 列的值在auths 表中不存在。
"
end。