首页 > 代码库 > 管理触发器
管理触发器
建立触发器时,ORACLE会将触发器信息写入到数据字典中,通过查询数据字典视图USER-TRIGGERS,可以显示当前用户所包含的所有触发器信息。
SQL> select trigger_name,status from user_triggers ; TRIGGER_NAME STATUS------------------------------ --------TR_INSTEAD_OF_DEPT_EMP ENABLEDTR_UPDATE_CASCADE ENABLEDTR_CHECK_SAL ENABLEDTR_SAL_CHANGE ENABLEDTR_EMP
2、禁止触发器
禁止触发器是指是使触发器临时失效。当触发器处于ENABLED状态时,如果在表上执行DML操作,则就会触发相应的触发器。如果基于INSERT操作建立了触发器,当使用SQL*Loader装载大批量数据时会触发触发器。为了加快数据装载速度,应该在装载数据之前禁止触发器。
SQL> alter trigger tr_check_sal disable; Trigger altered
3、激活触发器
激活触发器是指使触发器重新生效。当使用SQL*Loader装载了数据之后,为了使被禁止的触发器生效,应该激活触发器。
SQL> alter trigger tr_check_sal enable; Trigger altered
4、禁止或激活表的所有触发器
如果在表上同时存在多个触发器,那么使用ALTER TABLE命令可以一次禁止或激活所有触发器。
SQL> alter table emp disable all triggers; Table altered SQL> alter table emp enable all triggers; Table altered
5、重新编译触发器
当使用ALTER TABLE命令修改表的结构(例如增加列,删除列)时,会使得其触发器转变为INVALID状态。在这种情况下,为了使得触发器继续生效,需要重新编译触发器。
SQL> alter trigger tr_check_sal compile; Trigger altered
6、删除触发器
当触发器不再需要时,可以使用DROP TRIGGER命令删除触发器。注意,在表上的触发器越多,对于DML操作的性能影响越大,所以一定要适度使用触发器。
SQL> drop trigger tr_shutdown; Trigger dropped SQL> drop trigger tr_startup; Trigger dropped
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。