最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle触发器的使用

来源:动视网 责编:小采 时间:2020-11-09 10:51:27
文档

Oracle触发器的使用

Oracle触发器的使用:与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。系统事件触发器可以在DDL或数据库系统上被 1、定义 触发器:与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。 触发器触发次序
推荐度:
导读Oracle触发器的使用:与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。系统事件触发器可以在DDL或数据库系统上被 1、定义 触发器:与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。 触发器触发次序


与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。系统事件触发器可以在DDL或数据库系统上被

1、定义

触发器:与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。

触发器触发次序

1)执行 BEFORE语句级触发器;

2)对与受语句影响的每一行:

· 执行 BEFORE行级触发器

· 执行 DML语句

· 执行 AFTER行级触发器

3)执行 AFTER语句级触发器

2、DML触发器

触发类型--行级和表级

行级:触发语句处理每一行时,行级别触发器都激发一次。

通过:old访问原始值、:new访问修改后的值,:old和:new只在触发器内部有效。

触发时间--之前和之后

建立一个触发器, 当职工表 emp 表被删除一条记录时,把被删除记录写到职工表删除日志表中去

建立删除日志表

CREATE TABLE emp_his

AS SELECT * FROM EMP1 WHERE 1=2;

创建触发器

CREATE OR REPLACE TRIGGER del_emp

BEFORE DELETE OR UPDATE ON scott.emp1 FOR EACH ROW

BEGIN

INSERT INTO emp_his(deptno , empno, ename , job ,mgr , sal , comm , hiredate )

VALUES( :old.deptno, :old.empno, :old.ename , :old.job,

:old.mgr, :old.sal, :old.comm, :old.hiredate );

END;

3、INSTEAD-OF触发器:

INSTEAD OF选项使Oracle激活触发器,而不执行触发事件

instead-of触发器只能定义在视图上,允许修改一个本来无法修改的视图。

可更改视图指:如果对视图的操作都是对基表的修改,并只有一个基表。

不可更改视图反之。

建立测试视图

CREATE OR REPLACE VIEW emp_view AS

SELECT deptno,COUNT(*) total_employee,SUM(sal) total_salary

FROM emp1 GROUP BY deptno;

--SELECT * FROM user_views;

对视图操作报错

DELETE FROM emp_view WHERE deptno=10;

建立替代触发器

CREATE OR REPLACE TRIGGER emp_view_delete

INSTEAD OF DELETE ON emp_view FOR EACH ROW

BEGIN

DELETE FROM emp1 WHERE deptno=:old.deptno;

END;

再次执行DELETE

文档

Oracle触发器的使用

Oracle触发器的使用:与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。系统事件触发器可以在DDL或数据库系统上被 1、定义 触发器:与表或数据库事件联系在一起,当一个触发器事件发生时,定义在表上的触发器被触发执行。 触发器触发次序
推荐度:
标签: 使用 用法 数据库
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top