Oracle触发器

--创建一个触发器,使其可以修改tb_Department表的deptno。

create or replace trigger update_dept
after update on deptno
for each row
begin
update tb_Department set deptno=:new.deptno where deptno=:old.deptno;
end;
/

--建立一个语句级触发器,防止在非工作时间对于某个表的更新,插入和删除

create or replace trigger tr_dept_time
before insert or delete or update
on tb_Department
begin
if(to_char(sysdate, ‘DAY‘) in (‘星期六‘, ‘星期日‘)) or
 (to_char(sysdate, ‘HH24:MI‘) not between ‘08:00‘ and ‘18:00‘)
then
raise_application_error(-20001, ‘非工作时间,不能对tb_Department修改‘);
end if;
end;
/
select trigger_name, trigger_type from user_triggers
where table_name = ‘tb_Department‘;

-- 在tb_Department表中加入一个列,用于统计部门的总工资,在tb_Employee表上建立一个行级触发器,

-- 用于同步这个数据

alter table tb_Department add  sum_salary number(10) default 0;
declare
sum_sal tb_Employee.salary % type;
cursor dep_sal_cur is
select deptno,sum(sal) as sum_sal
from tb_Employee
group by deptno;
begin
for dep_sal in dep_sal_cur loop
update tb_Department
set sum_salary = dep_sal.sum_sal
where deptno = dep_sal.deptno;
end loop;
end;
create or replace trigger tri_emp_dep
after insert or delete or update of sal
on tb_Employee
for each row
begin
dbms_output.put_line(‘行触发器执行‘);
update departments
set sum_salary = sum_salary + nvl(:new.salary, 0) - nvl(:old.salary, 0);
end;
/

-- 使用序列和触发器,给流水号列自动添加流水号。

create sequence seq_table1
start with 1
increment by 1
maxvalue 9999999;
create table table1(num1 number, name1 varchar2(20));
create or replace trigger trg_table1
before insert on table1
for each row
declare
begin
select seq_table1.nextval into :new.num1 from dual;
end;
/

-- 在一个多事件的触发器中,使用条件谓词,对插入,删除,更新进行不同的处理。

create or replace trigger mul_event_tri
after insert or delete or update on table1
begin
case
when inserting then
dbms_output.put_line(‘data has been inserted‘);
when deleting then
dbms_output.put_line(‘data has been deleted‘);
when updating then
dbms_output.put_line(‘data has been updated‘);
end case;
end;
/

-- 建立一个审计表,把某个表更新,插入,删除的数据,通过行级触发器,记录到审计表,需要记

-- 录更新前后数据的变化,操作的类型和时间。

create table audit_table1(
old_num number,
new_num number,
old_name varchar2(20),
new_name varchar2(20),
op_type varchar2(20),
op_date varchar2(20)
);

create or replace trigger audit_tri
before update or insert or delete
on table1
for each row
declare
str varchar2(20);
begin
case
when updating then
str := ‘update‘;
when inserting then
str := ‘insert‘;
when deleting then
str := ‘delete‘;
end case;
insert into audit_table1 values(
:old.num1, :new.num1, :old.name1, :new.name1, str,
to_char(sysdate) || ‘ ‘ || to_char(sysdate, ‘HH24:MI‘));
end;
/
-- test --
insert into table1 values(17, ‘TFJ‘);
select * from table1;
select * from audit_table1;
-- test --
时间: 2024-11-11 03:11:15

Oracle触发器的相关文章

oracle触发器、序列、任务计划练习一例

今天在闲暇时间练习了一下oracle任务计划,具体详情如下 1.创建表 TBL_TIME create table tbl_time( id number not null,    /*id号*/ vsecond varchar2(2),   /* 秒*/ vtime varchar2(10)    /*当前时间*/ ) 2.创建序列 seq_tbltime create sequence seq_tbltime start with 1 increment by 1 nomaxvalue no

oracle 触发器与事务

(1)如果外部事务撤销,触发器形成的变更是否会撤销?如果触发器操作失败,是否会导致外部SQL失败,从而导致事务撤销(2) 事务回滚时,触发器形成的变更是否会撤销:(3) 触发器失败时,外部SQL是否会返回错误:如果会,则研究如何不返回错,如果不会,则研究如何会返回错误:(4) 触发器失败时(插入两条记录,前者成功,后者失败),事务回滚时触发器形成的变更是否会撤销:(5) 触发器失败时(插入两条记录,前者成功,后者失败),事务提交时触发器形成的变更是否会撤销: 答 在oracle中,对触发器的限制

oracle 触发器 学习笔记

触发器 是特定事件出现的时候,自动执行的代码块.类似于存储过程,但是用户不能直接调用他们. 功能: 1. 允许/限制对表的修改 2. 自动生成派生列,比如自增字段 3. 强制数据一致性 4. 提供审计和日志记录 5. 防止无效的事务处理 6. 启用复杂的业务逻辑 开始 create trigger biufer_employees_department_id before insert or update of department_id on employees referencing old

Oracle触发器如何调用Java实现Openfire消息发送

写在前面,要想实现整个过程的成功执行请先准备以下文件: 1. 登陆Openfire服务端以及Spark客户端相关程序(openfire_4_0_1.exe.spark_2_7_6.exe) 2. 连接Openfire和Oracle相关的jar包(presence.jar.smack.jar.smackx-debug.jar.smackx.jar.ojdbc.jar)  Step1:安装Openfire服务端并配置数据库连接,配置参考<Openfire服务器安装与配置教程> Step2:在Ecl

oracle触发器使用总结

永不放弃,一切皆有可能!!! 只为成功找方法,不为失败找借口! oracle触发器使用总结 1.说明 1)触发器是一种特殊的存储过程,触发器一般由事件触发并且不能接受参数,存储器由语句块去调用 2)触发器分类: 1.DML触发器: 创建在表上,由DML事件引发 2.instead of触发器: 创建在视图上并且只能在行级上触发,用于替代insert,delete等操作(由于oracle中不能直接对有两个以上的表建立的视图进行DML操作,所以给出替代触发器,它是专门为进行视图操作的一种处理方法)

Oracle 触发器在日志管理开发中的应用

摘要: 本文讨论了利用数据库中的触发器对日志管理进行设计与实现的方法, 是对原来在客户端软件中编写日志管理方法的一种改进, 并给出了 Oracle9i 中的实例演示.关键词: Oracle; 触发器; 日志管理中图分类号: TP311文献标识码: A文章编号: 1009- 3044(2008)16- 21186- 02The Application of Oracle Trigger in the Developing of Log ManagementWU Heng- liang, ZHANG

【database】oracle触发器基础

一.oracle触发器基本语法 CREATE [OR REPLACE] TRIGGER trigger_name {BEFORE | AFTER } {INSERT | DELETE | UPDATE [OF column [, column -]]} [OR {INSERT | DELETE | UPDATE [OF column [, column -]]}...] ON [schema.]table_name | [schema.]view_name [REFERENCING {OLD [

Mybatis 插入操作时获取主键 (Oracle 触发器与SEQ)

1.通过Oracle序列 -- Create sequence create sequence SEQ_DW_EWSYSTEM minvalue 1 maxvalue 999999999999999999999999999 start with 1 increment by 1 cache 20; <insert id="insertEwsystem" parameterType="Ewsystem"> <selectKey keyProperty

(转)oracle触发器使用:after insert 与before insert的简单使用注意

本文转载自:http://blog.csdn.net/kuangfengbuyi/article/details/41446125 创建触发器时,触发器类型为after insert , 在begin中 Select fieldA into v_a from tableA; 执行到此句时,会出错: --弹出错误信息提示 --ORA-04091:表tr_table发生了变化触发器/函数不能读它 --ORA-06512: 在iu_table line 2 --ORA-04088: 触发器iu_tab

问题:Oracle出发器;结果:1、Oracle触发器详解,2、Oracle触发器示例

ORACLE触发器详解 本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8.2.2 创建DML触发器 8.2.3 创建替代(INSTEAD OF)触发器 8.2.3 创建系统事件触发器 8.2.4 系统触发器事件属性 8.2.5 使用触发器谓词 8.2.6 重新编译触发器 8.3 删除和使能触发器 8.4 触发器和数据字典 8.5   数据库触发器的应用举例 触发器是许多关系数据库系