4、 触发器
create [or replace] trigger trigger_name 触发事件 触发事件
on {table_or_view_name|database}
[referencing [old [as] <old_name>][new [as] <new_name>]] //更新时用
[for each row [when condition]] //加上则为行级触发,否则为语句级触发
trigger_body
触发时间:
before:数据库动作之前触发器执行。
after:数据库动作之后触发器执行
instead of:触发器被触发,但相应的操作并不被执行,而运行的仅是触发器SQL语句本身。用在 使不可被修改的视图能够支持修改。
触发事件:
insert on:向表或视图插入一行时
update of:更新表或视图某一行时
delete on:删除表或视图某一行时
create:创建一个数据库对象时
alter:修改一个数据库对象时
drop:删除一个数据库对象时
start:打开数据库时触发触发器,在事件后触发
shutdown:关闭数据库时触发触发器,在事件前触发
logon:当一个会话建立时触发,事件前触发
logoff:关闭会话时触发,事件前触发
server:服务器错误发生时触发,事件后触发。
条件谓词:
inserting、updationg、deleting