人事管理系统Oracle触发器代码

合集下载

oracle触发器执行顺序

oracle触发器执行顺序

oracle触发器执行顺序2010-9-13表:emp--创建包变量CREATE PACKAGE EMP_PACKAGE lSold_sum NUMBER;--存放原来薪水总额new_sum NUMBER;--存放新的薪水总额test1 number;--before upate 对应值1test2 number;--before update each row 对应值2test3 number;--after update each row 对应值3test4 number;--after update 对应值4END;注:每个触发器执行都会对应上面变量进行赋值业务规则1:给员工加薪时,要扣税,扣税的规则是,原来薪水在5000或以上的扣除总薪水的10%,小于5000的扣除总薪水的20%业务规则2:如果目前全体员工的总薪水大于或等于15000,则不能加薪了;如果总薪水小于10000,则不能减薪了。

一.不同类型触发器(行级和语句)1.before触发器--原来总薪水总额(语句)CREATE OR REPLACE TRIGGER before_update_salaryBEFORE UPDATE ON EMPbeginSELECT SUM(salary)INTO EMP_PACKAGE.old_sum FROM EMP;EMP_PACKAGE.TEST1:=1;/*RAISE_APPLICATION_ERROR(-20003,nvl(EMP_PACKAGE.test2,0));*/end;--更改每行数据(行级)CREATE OR REPLACE TRIGGER before_add_salaryBEFORE UPDATE ON EMPFOR EACH rowBEGINif:new.salary>:OLD.salary THEN --加薪if:old.salary <5000THEN:NEW.salary :=:NEW.salary*0.8;RAISE_APPLICATION_ERROR(-20004,nvl(EMP_PACKAGE.test1,0));EMP_PACKAGE.TEST2:=2;ELSE:NEW.salary :=:NEW.salary*0.9;RAISE_APPLICATION_ERROR(-20005,nvl(EMP_PACKAGE.test1,0));EMP_PACKAGE.TEST2:=2;END IF;END IF;END;---现在对empno =5的员工薪水改为8000,执行得到以下报错(屏蔽before_update_salary报错)--现在对empno =5的员工薪水改为8000,执行得到以下报错(屏蔽before_add_salary报错)2.after触发器--判断员工新薪水(行级)create or replace trigger after_update_salary_rowafter UPDATE ON EMPfor each rowbeginif:new.salary>:OLD.salary THENif:new.salary <5000THEN/*RAISE_APPLICATION_ERROR(-20006,nvl(EMP_PACKAGE.test4,0));*/EMP_PACKAGE.test3:=3;ELSE/* RAISE_APPLICATION_ERROR(-20007,nvl(EMP_PACKAGE.test4,0));*/ EMP_PACKAGE.test3:=3;END IF;END IF;end;----判断是否可以加薪或减薪(语句)create or replace trigger after_update_salaryafter UPDATE ON EMPbeginSELECT SUM(salary)INTO EMP_PACKAGE.new_sum FROM EMP;if EMP_PACKAGE.new_sum> EMP_PACKAGE.old_sum thenif EMP_PACKAGE.old_sum>=15000thenRAISE_APPLICATION_ERROR(-20008,nvl(EMP_PACKAGE.test3,0));EMP_PACKAGE.test4:=4;end if;elseif EMP_PACKAGE.old_sum<10000thenRAISE_APPLICATION_ERROR(-20009,nvl(EMP_PACKAGE.test3,0));EMP_PACKAGE.test4:=4;end if;end if;end;--现在对empno =5的员工薪水改为8000,执行得到以下报错(屏蔽after_update_salary_row 报错)--现在对empno =5的员工薪水改为8000,执行得到以下报错(屏蔽after_update_salary报错)综合以上结果:oracle 一个表上的多个触发器的执行顺序如下:before 语句trigger->before 行级trigger->after 行级trigger->after 语句trigg er。

Oracle触发器trigger详解

Oracle触发器trigger详解

Oracle触发器trigger详解触发器相关概念及语法,供⼤家参考,具体内容如下概述本篇博⽂中主要探讨以下内容:什么是触发器触发器的应⽤场景触发器的语法触发器的类型案例数据:触发器的概念和第⼀个触发器数据库触发器是⼀个与表相关联的,存储的PL/SQL 语句。

每当⼀个特定的数据操作语句(insert update delete)在指定的表上发出时,Oracle⾃动执⾏触发器中定义的语句序列。

举个简单的例⼦:当员⼯表中新增⼀条记录后,⾃动打印“成功插⼊新员⼯”create or replace trigger insertStaffHintafter insert on xgj_testfor each rowdeclare-- local variables herebegindbms_output.put_line('新增员⼯成功');end insertStaffHint;触发器的应⽤场景复杂的安全性检查数据的确认数据库审计数据的备份和审计触发器的语法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 [AS] old | NEW [AS] new| PARENT as parent}][FOR EACH ROW ][WHEN condition]PL/SQL_BLOCK | CALL procedure_name;其中:BEFORE 和AFTER指出触发器的触发时序分别为前触发和后触发⽅式,前触发是在执⾏触发事件之前触发当前所创建的触发器,后触发是在执⾏触发事件之后触发当前所创建的触发器。

oracle windows操作语句

oracle windows操作语句

oracle windows操作语句Oracle是一种关系型数据库管理系统,广泛应用于企业级应用程序开发中。

在Windows操作系统上,可以使用Oracle SQL Developer或SQL*Plus等工具执行Oracle数据库操作语句。

下面列举了十个常用的Oracle Windows操作语句。

1. 创建表(CREATE TABLE)CREATE TABLE语句用于创建数据库中的表。

例如,创建一个名为“employees”的表,包含id、name和age三个字段:```sqlCREATE TABLE employees (id NUMBER,name VARCHAR2(100),age NUMBER);```2. 插入数据(INSERT INTO)INSERT INTO语句用于向表中插入数据。

例如,向“employees”表插入一条记录:```sqlINSERT INTO employees (id, name, age)VALUES (1, 'John', 25);```3. 更新数据(UPDATE)UPDATE语句用于更新表中的数据。

例如,将“employees”表中id为1的记录的年龄改为30:```sqlUPDATE employeesSET age = 30WHERE id = 1;```4. 删除数据(DELETE)DELETE语句用于删除表中的数据。

例如,删除“employees”表中id为1的记录:```sqlDELETE FROM employeesWHERE id = 1;```5. 查询数据(SELECT)SELECT语句用于从表中查询数据。

例如,查询“employees”表中的所有记录:```sqlSELECT * FROM employees;```6. 创建索引(CREATE INDEX)CREATE INDEX语句用于在表上创建索引,以提高查询性能。

Oracle触发器操作

Oracle触发器操作

AS
SELECT * FROM Users
WHERE u_Name='amy';

(2)创建行级触发器

CREATE OR REPLACE TRIGGER tr_DeleteUser2 AFTER DELETE
2020/10/15 Or acle 数 据库 管理 与 应用 实例 教 程
课堂案例2—使用PL/SQL管理触发器
案例完成步骤-创建触发器
添加标 【例2-4】通过临时表将Users表中删除的记录进行临时保存(行级触发器)。
(1)创建行级触发器的测试表 CREATE TABLE userdel
题文字
建议课时:8课时
2020/10/15 Or acle 数 据库 管理 与 应用 实例 教 程
9.1 触发器概述
触发器简介 触发器是一种特殊的存储过程,它与数据表紧密联系,用于保护表中的 数据,当一个定义了特定类型触发器的基表执行插入、修改或删除表中 数据的操作时,将自动触发触发器中定义的操作,以实现数据的一致性 和完整性。 触发器拥有比数据库本身标准的功能更精细和更复杂的数据控制能力。 触发器具有以下的作用: (1)在安全性方面,触发器可以基于数据库的值使用户具有操作数据 库的某种权利。 (2)在审计方面,触发器可以跟踪用户对数据库的操作。 (3)实现复杂的数据完整性规则。 (4)实现复杂的非标准的数据库相关完整性规则。触发器可以对数据 库中相关的表进行连环更新。 (5)同步实时地复制表中的数据。 (6)自动计算数据值,如果数据的值达到了一定的要求,则进行特定 的处理。例如,如果商品的数量低于5,则立即给管理人员发送库存报 警信息。

WHO VARCHAR2(30),

Oracle数据库之PLSQL触发器

Oracle数据库之PLSQL触发器

Oracle数据库之PLSQL触发器Oracle数据库之PL/SQL触发器1. 介绍触发器(trigger)是提供给程序员和数据分析员来保证数据完整性的⼀种⽅法,它是与表事件相关的特殊的存储过程,它的执⾏不是由程序调⽤,也不是⼿⼯启动,⽽是由事件来触发,⽐如当对⼀个表进⾏操作(insert,delete,update)时就会激活它执⾏。

触发器经常⽤于加强数据的完整性约束和业务规则等。

触发器有三种类型,分别是:DML触发器、替代触发器和系统触发器。

DML触发器顾名思义,DML触发器是由DML语句触发的。

例如数据库的INSERT、UPDATE、DELETE操作都可以触发该类型的触发器。

它们可以在这些语句之前或之后触发,或者在⾏级上触发(就是说对于每个受影响的⾏都触发⼀次)。

替代触发器替代触发器只能使⽤在视图上,与DML不同的是,DML触发器是运⾏在DML之外的,⽽替代触发器是代替激发它的DML语句运⾏。

替代触发器是⾏触发器。

系统触发器这种触发器是发⽣在如数据库启动或关闭等系统事件时,不是在执⾏DML语句时发⽣,当然也可以在DDL时触发。

触发器功能强⼤,轻松可靠地实现许多复杂的功能,但是我们也应该慎⽤。

为什么⼜要慎⽤呢?触发器本⾝没有过错,但如果我们滥⽤,会造成数据库及应⽤程序的维护困难。

在数据库操作中,我们可以通过关系、触发器、存储过程、应⽤程序等来实现数据操作,同时约束、缺省值也是保证数据完整性的重要保障。

如果我们对触发器过分的依赖,势必影响数据库的结构,同时增加了维护的复杂程度。

2. 触发器组成触发器主要由以下⼏个要素组成:1. 触发事件:引起触发器被触发的事件。

2. 触发时间:触发器是在触发事件发⽣之前(BEFORE)还是之后(AFTER)触发,也就是触发事件和该触发器的操作顺序。

3. 触发操作:触发器被触发之后的⽬的和意图,是触发器本⾝要做的事情。

4. 触发对象:包括表、视图、模式、数据库。

oracle触发器的实例(转)

oracle触发器的实例(转)

oracle触发器的实例(转)触发器使⽤教程和命名规范⽬录触发器使⽤教程和命名规范 11,触发器简介 12,触发器⽰例 23,触发器语法和功能 34,例⼀:⾏级触发器之⼀ 45,例⼆:⾏级触发器之⼆ 46,例三:INSTEAD OF触发器 67,例四:语句级触发器之⼀ 88,例五:语句级触发器之⼆ 99,例六:⽤包封装触发器代码 1010,触发器命名规范 111,触发器简介触发器(Trigger)是数据库对象的⼀种,编码⽅式类似存储过程,与某张表(Table)相关联,当有DML语句对表进⾏操作时,可以引起触发器的执⾏,达到对插⼊记录⼀致性,正确性和规范性控制的⽬的。

在当年C/S时代盛⾏的时候,由于客户端直接连接数据库,能保证数据库⼀致性的只有数据库本⾝,此时主键(Primary Key),外键(Foreign Key),约束(Constraint)和触发器成为必要的控制机制。

⽽触发器的实现⽐较灵活,可编程性强,⾃然成为了最流⾏的控制机制。

到了B/S时代,发展成4层架构,客户端不再能直接访问数据库,只有中间件才可以访问数据库。

要控制数据库的⼀致性,既可以在中间件⾥控制,也可以在数据库端控制。

很多的青睐Java的开发者,随之将数据库当成⼀个⿊盒,把⼤多数的数据控制⼯作放在了Servlet中执⾏。

这样做,不需要了解太多的数据库知识,也减少了数据库编程的复杂性,但同时增加了Servlet编程的⼯作量。

从架构设计来看,中间件的功能是检查业务正确性和执⾏业务逻辑,如果把数据的⼀致性检查放到中间件去做,需要在所有涉及到数据写⼊的地⽅进⾏数据⼀致性检查。

由于数据库访问相对于中间件来说是远程调⽤,要编写统⼀的数据⼀致性检查代码并⾮易事,⼀般采⽤在多个地⽅的增加类似的检查步骤。

⼀旦⼀致性检查过程发⽣调整,势必导致多个地⽅的修改,不仅增加⼯作量,⽽且⽆法保证每个检查步骤的正确性。

触发器的应⽤,应该放在关键的,多⽅发起的,⾼频访问的数据表上,过多使⽤触发器,会增加数据库负担,降低数据库性能。

oracle触发器if条件与逻辑写法

oracle触发器if条件与逻辑写法

oracle触发器if条件与逻辑写法Oracle触发器IF条件与逻辑的写法:1. IF条件语句简介IF条件语句是一种基本的结构化程序设计语句,它在Oracle触发器中也是非常常用的。

IF条件语句根据给定条件,决定是否执行特定的代码块。

在Oracle触发器中,IF条件语句常常用于对数据进行操作之前的条件判断。

2. IF条件语句的语法IF条件语句的语法非常简单,其一般形式为:IF(condition) THEN statement_block;END IF;其中,condition是判断条件,当满足此条件时,执行statement_block 中的代码块。

3. IF条件语句的逻辑操作符在IF条件语句中,除了可以用比较操作符(比如“=”、“<”、“>”等)作为条件判断之外,还可以使用逻辑操作符。

常用的逻辑操作符包括:• AND:表示同时满足两个条件时,IF语句才执行。

• OR:表示两个条件中有一个满足时,IF语句执行。

• NOT:表示条件为假时,IF语句执行。

4. IF条件语句的多重判断IF条件语句也可以进行多重判断,这样可以根据不同的情况执行不同的代码块。

其形式为:IF condition1 THENstatement_block1;ELSIF condition2 THENstatement_block2;ELSIF condition3 THENstatement_block3;ELSEstatement_block4;END IF;其中,当condition1满足时,执行statement_block1;当condition1不满足,但condition2满足时,执行statement_block2;以此类推,如果所有条件都不满足,才执行statement_block4。

5. IF条件语句的嵌套IF条件语句还可以进行嵌套,即在一个IF语句中嵌套另一个IF语句。

这种嵌套可以实现更加复杂的条件判断。

oracle 触发器case 写法

oracle 触发器case 写法

Oracle触发器是一种特殊类型的存储过程,它可以在特定的数据库操作发生时自动执行。

在实际应用中,我们经常会遇到需要使用Oracle触发器来实现一些复杂的业务逻辑。

在使用Oracle触发器时,我们需要根据具体的业务需求来设计触发器的逻辑,而针对不同的场景,需要使用不同的触发器写法。

本文将针对Oracle触发器的不同应用场景,介绍其对应的写法和注意事项。

一、触发器简介1.1 触发器概述Oracle触发器是一种特殊的数据库对象,它会在特定的数据库操作(如INSERT、UPDATE、DELETE)发生时自动触发执行。

触发器可以在数据库级别定义,对于特定的表和事件进行相应的响应操作。

在实际应用中,触发器常用于实现数据完整性约束、数据审计、实时计算等功能。

1.2 触发器类型在Oracle数据库中,触发器主要分为行级触发器和语句级触发器两种类型。

行级触发器会在每一行数据被操作时触发执行,而语句级触发器则会在整个SQL语句执行完成时触发执行。

在设计触发器时,需要根据具体的业务需求来选择合适的触发器类型。

二、Oracle触发器的应用场景及写法2.1 实现数据完整性约束在数据库中,我们经常需要实现一些数据完整性约束,如主键约束、外键约束等。

而触发器可以作为实现这些约束的一种手段。

我们可以使用触发器在插入或更新数据时,对数据进行校验,确保符合特定的约束条件。

对于主键约束,我们可以使用BEFORE INSERT触发器来实现,在数据插入前对主键进行校验,防止重复插入数据。

示例代码如下:```sqlCREATE OR REPLACE TRIGGER trg_check_pkBEFORE INSERT ON table_nameFOR EACH ROWDECLAREv_count NUMBER;BEGINSELECT COUNT(*) INTO v_countFROM table_nameWHERE primary_key = :new.primary_key;IF v_count > 0 THENR本人SE_APPLICATION_ERROR(-0, 'Primary key already exists');END IF;END;/```对于外键约束,我们可以使用AFTER INSERT、AFTER UPDATE触发器来实现,在数据插入或更新后对外键进行校验,确保引用的数据存在。

oracle序列和触发器

oracle序列和触发器

oracle序列和触发器1、创建表t1 :create table t1 (id number,name nvarchar(8));2、创建序列:CREATE SEQUENCE t1_id INCREMENT BY 1 START WITH 1 MAXV ALUE 1.0E28 MINV ALUE 1 NOCYCLE CACHE 20 NOORDER3. 创建触发器:CREATE TRIGGER tig_insert_t1BEFORE INSERT ON "YINZQ"."T1"beginif (:new.id is null) thenselect t1_id.nextval into :new.id from dual; //其中的:new.id 指的是t1表中新行的列end if;end;Oracle触发器语法触发器是特定事件出现的时候,自动执行的代码块。

类似于存储过程,触发器与存储过程的区别在于:存储过程是由用户或应用程序显式调用的,而触发器是不能被直接调用的。

功能:1、允许/限制对表的修改2、自动生成派生列,比如自增字段3、强制数据一致性4、提供审计和日志记录5、防止无效的事务处理6、启用复杂的业务逻辑触发器触发时间有两种:after和before。

1、触发器的语法:CREATE [OR REPLACE] TIGGER触发器名触发时间触发事件ON表名[FOR EACH ROW]BEGINpl/sql语句END其中:触发器名:触发器对象的名称。

由于触发器是数据库自动执行的,因此该名称只是一个名称,没有实质的用途。

触发时间:指明触发器何时执行,该值可取:before---表示在数据库动作之前触发器执行;after---表示在数据库动作之后出发器执行。

触发事件:指明哪些数据库动作会触发此触发器:insert:数据库插入会触发此触发器;让oracle实现自增字段先建序列,然后建立一个触发器实现!cata0是表名,cata0_id是需要自增的字段!CREATE SEQUENCE SEQ_cata0INCREMENT BY 1START WITH 1MAXV ALUE 9999999CREATE TRIGGER TRG_cata0 BEFOREINSERT ON cata0FOR EACH ROW beginSELECT SEQ_cata0.NEXTV ALINTO :NEW.cata0_IDfrom DUAL;End TRG_cata0;/****@PARAM STNAME 不要创建序列的表,多个表则以“,”隔开**/CREATE OR REPLACE PROCEDURE PROC_CREATE_SEQ_TRIG(STNAME IN V ARCHAR2)ASSTRSQL VARCHAR2(4000);TABLENAME V ARCHAR2(50);PID V ARC ......。

Oracle存储过程和触发器基本操作

Oracle存储过程和触发器基本操作

南华大学计算机科学与技术学院实验报告(2012~2013 学年度第二学期)课程名称Oracle高级数据库开发设计实验名称存储过程与触发器基本操作姓名学号专业班级地点教师前提表脚本:create table S_RZ0122 (Sno varchar2(11) primary key,Sname varchar2(20) not null,Ssex varchar(2) not null ,Sage number(2) not null,Sdept varchar(20) not null)create table C_RZ0122(Cno varchar2(20) primary key,Cname varchar2(20) not null ,Ccredit number(2) not null)create table SC_RZ0122(Sno varchar2(11) not null,Cno varchar2(20) not null,Score number(3) ,primary key(Sno ,Cno),foreign key(Sno) references S_RZ0122(Sno),foreign key(Cno) references C_RZ0122(Cno))INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0811101,'李勇','男',21,'计算机系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0811102,'刘晨','男',20,'计算机系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0811103,'王敏','女',20,'计算机系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0811104,'张小红','女',19,'计算机系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0821101,'张立','男',20,'信息管理系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0821102,'吴宾','女',19,'信息管理系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0821103,'张海','男',20,'信息管理系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0831101,'钱小平','女',21,'通信工程系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0831102,'王大力','男',20,'通信工程系')INSERT INTO S_RZ0122 (Sno ,Sname,Ssex,Sage ,Sdept) V ALUES(0831103,'张珊珊','女',19,'通信工程系')---增加课程信息脚本:---insert allINSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C001','高等数学',4) INSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C002','大学英语',3) INSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C003','大学英语',3) INSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C004','计算机文化学',2) INSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C005','VB',2)INSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C006','数据库基础',4) INSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C007','数据结构',4) INSERT INTO C_RZ0122 (Cno ,Cname ,Ccredit ) V ALUES ('C008','计算机网络',4) select * from C_RZ0122;---增加关联学生和课程信息脚本:---INSERT ALLINSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0811101,'C001',96)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0811101,'C002',80)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0811101,'C003',84)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0811101,'C005',62)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0811102,'C001',92)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0811102,'C002',90)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0811102,'C004',84)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0821102,'C001',76)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0821102,'C004',85)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0821102,'C005',73)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0821102,'C007',0)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0821103,'C001',50)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0821103,'C004',80)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0831101,'C001',50)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0831101,'C004',80)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0831102,'C007',0)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0831103,'C004',78)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0831103,'C005',65)INSERT INTO SC_RZ0122(Sno,Cno,Score) V ALUES (0831103,'C007',0)select Sno,Cno,Score from SC_RZ0122;一.实验题目存储过程与触发器基本操作二.实验要求掌握对存储过程和触发器的创建、修改等基本操作。

oracle 触发器的种类和触发事件,dml触发器,ddl事件触发器,替代触发器,查看触发

oracle 触发器的种类和触发事件,dml触发器,ddl事件触发器,替代触发器,查看触发

oracle 触发器的种类和触发事件,DML触发器,DDL事件触发器,替代触发器,查看触发...oracle 数据库开发应用实例,招生录取系统 ... | oracle 创建,删除存储过程,参数传递,创 ...2009-04-14oracle 触发器的种类和触发事件,DML触发器,DDL事件触发器,替代触发器,查看触发器,关键字: oracle 触发器种类触发事件dml ddl 事件替代查看触发器的种类和触发事件触发器必须由事件才能触发。

触发器的触发事件分可为3类,分别是DML事件、DDL事件和数据库事件。

每类事件包含若干个事件,如下所示。

数据库的事件是具体的,在创建触发器时要指明触发的事件。

种类关键字含义Sql代码DML事件(3种) INSERT 在表或视图中插入数据时触发UPDATE 修改表或视图中的数据时触发DELETE 在删除表或视图中的数据时触发DDL事件(3种) CREATE 在创建新对象时触发ALTER 修改数据库或数据库对象时触发DROP 删除对象时触发数据库事件(5种) STARTUP 数据打开时触发SHUTDOWN 在使用NORMAL或IMMEDIATE选项关闭数据库时触发LOGON 当用户连接到数据库并建立会话时触发LOGOFF 当一个会话从数据库中断开时触发SERVERERROR 发生服务器错误时触发DML事件(3种) INSERT 在表或视图中插入数据时触发UPDATE 修改表或视图中的数据时触发DELETE 在删除表或视图中的数据时触发DDL事件(3种) CREATE 在创建新对象时触发ALTER 修改数据库或数据库对象时触发DROP 删除对象时触发数据库事件(5种) STARTUP 数据打开时触发SHUTDOWN 在使用NORMAL或IMMEDIATE选项关闭数据库时触发LOGON 当用户连接到数据库并建立会话时触发LOGOFF 当一个会话从数据库中断开时触发SERVERERROR 发生服务器错误时触发触发器的类型可划分为4种:数据操纵语言(DML)触发器、替代(INSTEAD OF)触发器、数据定义语言(DDL)触发器和数据库事件触发器。

oracle触发器-解决mutating table的问题

oracle触发器-解决mutating table的问题

Oracle触发器mutating table问题解决方案一、问题描述Oracle触发器是特定事件出现的时候,自动执行的代码块。

但在使用过程中,往往遇到如下需求:1、在触发器执行时,使用DML语言操作触发器的基础表,完成更新、插入或删除操作;2、触发器对于父子表,即有外键关联的表的相关操作;或者说trigger访问了自身上的表。

在以上两种情况下,依据Oracle的事务处理规则,通常产生如下错误:ORA-04091。

该错误解释为:当前的trigger下的事物,access(执行)了一个mutating table(冲突的表)。

一个简单的例子拿oracle的示例表emp和dept来做这个试验。

dept的表结构如下:emp表结构如下:emp和dept是一对父子表,关联column为DEPTNO。

接下来创建1个table:emp_log 和1个语句级trigger: emp_del_trg。

取一个最简单的业务功能,emp_del_trg的作用就是当表emp记录被删除的时候,触发器将删除的记录的EMPNO,DNAME和删除时间写入到emp_log中,当子表依赖的父表相关记录删除的时候,emp_log不做处理。

表emp_log的结构如下:触发器trigger代码如下:来看看这个触发器是否能正常工作,首先删除emp的记录。

看似trigger工作正常,删除dept的记录呢?问题分析:ORA-04091错误如约而至。

不难解释,因为父子表指定了级联删除,删除dept的记录从而引起删除emp表上的相应数据,然后触发了emp_del_trg,由于trigger里有对dept的访问,对当前事务说,dept就是一个mutating table,这是不被允许的。

如何来解决这个问题而实现这个简单的业务逻辑功能呢?当然,从表结构逻辑设计上来讲,可以将dept表上的dname字段add到emp表,或者不要显式的指定references,用程序来维护数据的完整性和约束,然后调整业务代码.最直接的方法,在trigger中声明一个ora-04091的exception,对此异常不做处理,也可完成目的。

oracle 触发器(trigger)

oracle 触发器(trigger)

触发器的使用1触发器资料来源:《/view/71791.htm?fr=ala0_1_1》触发器(trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作(insert,delete,update)时就会激活它执行。

触发器经常用于加强数据的完整性约束和业务规则等。

触发器可以从DBA_TRIGG ERS ,USER_TRIGGERS 数据字典中查到。

1.1 数据库领域名词触发器可以查询其他表,而且可以包含复杂的SQL语句。

它们主要用于强制服从复杂的业务规则或要求。

例如:您可以根据客户当前的帐户状态,控制是否允许插入新订单。

触发器也可用于强制引用完整性,以便在多个表中添加、更新或删除行时,保留在这些表之间所定义的关系。

然而,强制引用完整性的最好方法是在相关表中定义主键和外键约束。

如果使用数据库关系图,则可以在表之间创建关系以自动创建外键约束。

1.2 创建触发器的SQL语法DELIMITER |CREATE TRIGGER `<databaseName>`.`<triggerName>`< [ BEFORE | AFTER ] > < [ INSERT | UPDATE | DELETE ] >ON <tableName>FOR EACH ROWBEGIN--do somethingEND |1.3 触发器的优点触发器可通过数据库中的相关表实现级联更改;不过,通过级联引用完整性约束可以更有效地执行这些更改。

触发器可以强制比用CHECK 约束定义的约束更为复杂的约束。

与CHECK 约束不同,触发器可以引用其它表中的列。

例如,触发器可以使用另一个表中的SELECT 比较插入或更新的数据,以及执行其它操作,如修改数据或显示用户定义错误信息。

触发器也可以评估数据修改前后的表状态,并根据其差异采取对策。

oracle触发器delete写法

oracle触发器delete写法

oracle触发器delete写法Oracle触发器是数据库中一种特殊类型的存储过程,它会在特定的数据库操作(如插入、更新或删除)发生时自动运行。

在本文中,我们将详细介绍Oracle触发器的删除写法。

要删除一个Oracle触发器,我们可以使用DROP TRIGGER语句。

该语句的基本语法如下:DROP TRIGGER trigger_name;其中,trigger_name是要删除的触发器的名称。

值得注意的是,删除触发器需要具有适当的权限。

在删除触发器之前,我们可以使用以下语句查询数据库中的所有触发器:SELECT trigger_name, trigger_type, triggering_event,table_owner, base_object_type, table_nameFROM all_triggersWHERE owner = 'schema_name';其中,trigger_name是触发器的名称,trigger_type是触发器的类型(如BEFORE或AFTER),triggering_event是触发器所响应的事件(如INSERT、UPDATE或DELETE),table_owner是触发器所属的表的所有者,base_object_type是基本对象类型(如TABLE),table_name是触发器所属的表的名称。

要删除一个触发器,我们可以使用以下语句:DROP TRIGGER trigger_name;其中,trigger_name是要删除的触发器的名称。

在删除触发器之前,我们应确保没有其他数据库对象依赖于该触发器。

可以使用以下语句查询依赖于触发器的对象:SELECT owner, object_name, object_typeFROM all_dependenciesWHERE referred_name = 'trigger_name'AND referred_type = 'TRIGGER';其中,trigger_name是要删除的触发器的名称。

Oracle记录登录失败的触发器

Oracle记录登录失败的触发器

Oracle 记录登录失败的触发器前⾔:实现的功能主要是,oracle 登录成功记录登录⽤户ip 地址,登录失败记录登录失败ip 地址1,需要建⽴⼀个触发器记录登录成功的客户端⽤户的ip 地址⼤家都知道在v$session 中记录着客户端的机器名称,但是没有IP , 如果记录clinet ip 呢?先运⾏DBMS_SESSION 过程包注册,然后执⾏存储过程on_logon_trigger ,这样当客户端登陆后,在v$session 的client_info 列会记录其相应的IP 信息。

利⽤ DBMS_SESSION 过程包,先执⾏12345BEGIN DBMS_SESSION.set_identifier(SYS_CONTEXT('USERENV', 'IP_ADDRESS'));END;再执⾏触发器trigger123456789createorreplacetrigger on_logon_trigger after logon ondatabasebegindbms_application_info.set_client_info(sys_context( 'userenv', 'ip_address' ) );end;执⾏这些过程包触发器需要dba 权限。

2,然后使⽤超级管理员通过plsql 登录,就可以查看连接上oracle 的ip 信息:执⾏查询SQL :1234567select username,program,machine,client_info,sys_context('userenv','ip_address') as ipadd from v$session swhere username isnotnullorderby username,program,machine;信息如下所⽰:3,建⽴触发器实现登录失败的时候记录⽇志信息:写⼀个触发器,触发器的信息记录在alert ⽇志⾥⾯,通过查看alert ⽇志来获取登录失败的⽤户信息。

oracle中触发器写判断语句,Oracle触发器介绍语句级触发器

oracle中触发器写判断语句,Oracle触发器介绍语句级触发器

oracle中触发器写判断语句,Oracle触发器介绍语句级触发器语句级触发器我们先看⼀个AFTER-INSERT-STATEMENT触发器:CREATE OR REPLACE TRIGGER temp_aisAFTER INSERT ON TEMPBEGINdbms_output.put_line(‘executing temp_ais‘);END;看⼀下下⾯语句的结果:SQL> set feedback offSQL> INSERT INTO temp VALUES (1); -- insert 1 rowexecuting temp_aisSQL> INSERT INTO temp VALUES (1); -- insert 1 rowexecuting temp_aisSQL> INSERT INTO temp SELECT * FROM temp; -- insert 2 rowsexecuting temp_ais每个SQL插⼊语句将触发⼀次,⾏级触发器最后⼀条语句要触发两次。

⼀、事件顺序⽤Insert 语句级触发器可以做:·可以在表上执⾏⼀个合计运算,可以在insert前或后来计算。

·可以使⽤语句级触发器去处理⾏级触发器控制的数据。

·可以给事件发信号。

可以仅仅是⼀个打印语句。

也可以是⼀个email或使⽤DBMS_ALERT包向其他处理过程发送信号。

Tasks PerformedStages ----------------------------------------------------- ———> | Rehect the |Fires once | BIS function | | Transaction |per statement | Statement Level Trigger | ------------------------------------------------------ ———> -------------------| | Take Action || -------------------insert |3⾏记录 | -------------------------- |————> | | Row Trigger | | -------------------------------————> | -------------------------- | |每⼀个⾏触发器插⼊⼀|————> | | | |⾏触发⼀次,插⼊三⾏|| ---------------------------------------- | |触发三次,语句级触发|| | Oracle enforces constraints | | |器在⾏操作和⾏数据上|| ---------------------------------------- | |不可见 || | | | || -------------------------- | -------------------------------| | Row Trigger | || -------------------------- ||| -------------------------------------------------------- ————> | Rehect the |Fires once | AIS function | | Transaction |per statement | Statement Level Trigger | ------------------------------------------------------- ————> --------------------| Take Action |--------------------上图显⽰了语句级出发器的⾏为。

oracle 触发器case写法

oracle 触发器case写法

Oracle触发器是一种用于在数据库发生特定事件时自动执行某些操作的数据库对象。

触发器可以用于在数据插入、更新或删除时执行特定的逻辑,以确保数据的完整性和一致性。

在Oracle数据库中,触发器是一种强大的工具,可以帮助数据库开发人员实现复杂的业务逻辑和数据处理需求。

在使用Oracle触发器时,我们需要根据具体的业务需求来编写相应的触发器,以确保触发器能够正确地响应数据库中发生的事件,并执行相应的操作。

在编写Oracle触发器时,我们需要遵循一定的写法和规范,以确保触发器的可靠性和可维护性。

以下是关于Oracle触发器编写的一些常见的写法和注意事项:1. 指定触发器的事件类型和触发时机在编写Oracle触发器时,首先需要明确触发器要响应的事件类型和触发时机。

Oracle触发器可以在数据插入(INSERT)、更新(UPDATE)或删除(DELETE)时触发,我们需要根据具体的业务需求来选择合适的事件类型和触发时机。

2. 触发器的创建和定义在指定了触发器要响应的事件类型和触发时机之后,我们需要使用CREATE TRIGGER语句来创建和定义触发器。

在触发器的定义中,需要指定触发器的名称、所属的表名、触发时机以及触发器的逻辑。

3. 触发器的语法和逻辑在编写Oracle触发器的逻辑时,需要使用PL/SQL语言来实现触发器的逻辑。

我们可以在触发器中编写适当的PL/SQL代码来执行数据处理、业务逻辑或其他操作。

在编写触发器的逻辑时,需要确保逻辑的正确性和可靠性,以确保触发器能够正确地执行所需的操作。

4. 考虑触发器的性能和效率在编写Oracle触发器时,需要考虑触发器的性能和效率。

触发器的逻辑和操作可能会对数据库的性能产生影响,我们需要审慎地编写触发器的逻辑,以确保触发器能够在不影响数据库性能的情况下正确地执行所需的操作。

5. 测试和调试触发器在编写Oracle触发器之后,需要对触发器进行测试和调试,以确保触发器能够正确地响应所需的事件,并执行相应的操作。

oracle触发器delete写法

oracle触发器delete写法

概述:本文将针对Oracle数据库中触发器的delete写法展开讨论,通过逐步介绍触发器的基本概念和使用方法,深入探究delete触发器的写法以及相关注意事项。

文章将以从简到繁的方式,帮助读者全面理解delete触发器的实现原理和应用技巧。

一、触发器的基本概念和使用方法1.1 触发器的概念和作用在Oracle数据库中,触发器是一种特殊的存储过程,它是与表相关联的数据库对象,当表上出现特定的事件,比如insert、update或delete操作时,触发器会自动执行相应的动作。

1.2 触发器的创建和语法在创建触发器时,需要指定触发的事件(insert、update或delete)、触发的时机(before或after)以及触发的操作(行级触发器或语句级触发器)。

触发器的语法如下:```sqlCREATE [OR REPLACE] TRIGGER trigger_nameBEFORE/AFTER INSERT/UPDATE/DELETEON table_name[FOR EACH ROW]BEGIN-- 触发器执行的动作END;```1.3 触发器的应用场景触发器通常用于实现数据的自动化维护、约束的强制执行等应用场景。

delete触发器作为其中的一种,可以在数据删除操作时执行一系列特定的逻辑处理,保证数据的完整性和一致性。

二、delete触发器的写法及注意事项2.1 delete触发器的基本写法在创建delete触发器时,需要注意触发时机、执行动作和逻辑处理。

delete触发器通常在数据删除之前或之后执行,可以用于记录日志、更新相关数据等操作。

以下是delete触发器的基本写法示例:```sqlCREATE OR REPLACE TRIGGER delete_triggerBEFORE DELETEON table_nameFOR EACH ROWBEGIN-- 执行相关逻辑处理END;```2.2 delete触发器的注意事项在编写delete触发器时,需要注意以下几点:- 触发时机的选择:根据业务需求和数据完整性考虑,选择合适的触发时机(before或after)。

Oracle触发器详解

Oracle触发器详解

Oracle触发器详解一、触发器概述触发器是特定事件出现的时候,自动执行的代码块。

类似于存储过程,但是用户不能直接调用他们。

功能:1、 允许/限制对表的修改2、 自动生成派生列,比如自增字段3、 强制数据一致性4、 提供审计和日志记录5、 防止无效的事务处理6、 启用复杂的业务逻辑触发器触发时间有两种:after和before。

1、触发器的语法:CREATE [OR REPLACE] TIGGER触发器名 触发时间 触发事件ON表名[FOR EACH ROW]BEGINpl/sql语句END其中:触发器名:触发器对象的名称。

由于触发器是数据库自动执行的,因此该名称只是一个名称,没有实质的用途。

触发时间:指明触发器何时执行,该值可取:before---表示在数据库动作之前触发器执行;after---表示在数据库动作之后出发器执行。

触发事件:指明哪些数据库动作会触发此触发器:insert:数据库插入会触发此触发器;update:数据库修改会触发此触发器;delete:数据库删除会触发此触发器。

表名:数据库触发器所在的表。

for each row:对表的每一行触发器执行一次。

如果没有这一选项,则只对整个表执行一次。

触发器的组成部分:1、 触发器名称2、 触发语句3、 触发器限制4、 触发操作触发器类型:1、 语句触发器2、 行触发器3、 INSTEAD OF 触发器4、 系统条件触发器5、 用户事件触发器注释:before和after:指在事件发生之前或之后激活触发器。

instead of:如果使用此子句,表示可以执行触发器代码来代替导致触发器调用的事件。

insert、 delete和update:指定构成触发器事件的数据操纵类型,update还可以制定列的列表。

此类触发器用的不多,经常用于视图,不做重点。

table_or_view_name:指要创建触发器的表或视图的名称。

for each row:指定是否对受影响的每行都执行触发器,即行级触发器,如果不使用此子句,则为语句级触发器。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

--创建基于考核表上的触发器,在录入数据时依据总评进行考核等级的输入create or replace trigger WR
before insert on WorkReview
for each row
begin
:new.Wresult:=:new.Wattendence*0.3+:new.Wwork*0.7;
if :new.Wresult>=0 and :new.Wresult<=59 then
:new.Wstatus:='不及格' ;
elsif :new.Wresult>= 60 and :new.Wresult<= 69 then
:new.Wstatus:='及格';
elsif :new.Wresult >= 70 and :new.Wresult<= 89 then
:new.Wstatus:='良好' ;
elsif :new.Wresult >= 90 and :new.Wresult<= 100 then
:new.Wstatus:='优秀' ;
end if;
end;
---创建加班费可以在录入数据时自动计算其加班费进行加班费的结算
create or replace trigger Overtime_trigger
before insert on Overtime
for each row
begin
if:new.OverType='一般' then
:new.OverCost:= :new.OverTime*10;
elsif :new.OverType='节假' then
:new.OverCost:= :new.OverTime*10;
end if;
end;
-创建触发器LateCost_trigger在录入数据时对员工迟到进行自动扣费计算create or replace trigger LateCost_trigger
before insert on AttendRecord
for each row
begin
:new.Noattend:=:new.LeaveTime+:new.EveTime+:new.Awaywork;
--迟到3次以及3次以上扣费120
if :tetime>=3 then
:teCost:=120;
--迟到2次扣费80
elsif :tetime=2 then
:teCost:=80;
--迟到1次扣费40
elsif :tetime=1 then
:teCost:=40 ;
--迟到0次扣费0
elsif :tetime=0 then
:teCost:=0 ;
end if;
end;
--录入员工培训考核成绩得总评和考核等级
create or replace trigger TR
before insert on Trainresult
for each row
begin
:new.Trresult:= :new.Trattendence*0.3+ :new.Trtest*0.7;
if :new.Trresult >= 0 and :new.Trresult<=59 then
:new.Tstatus:='不及格';
elsif :new.Trresult >= 60 and :new.Trresult<=69 then
:new.Tstatus:='及格';
elsif :new.Trresult >= 70 and :new.Trresult<=89 then
:new.Tstatus:='良好';
elsif :new.Trresult >= 90 and :new.Trresult<=100 then
:new.Tstatus:='优秀';
end if;
end;
--当在员工工作变动时,在修改员工的基本信息时,将变动信息自动插入到工作变动单中--当员工的工资信息变动时,将变动信息插入到工资变动日志中
--录入加班费
create or replace procedure Caculate_OverCoat
is
begin
update Salary
set OverCost =
(select OverCost from Overtime
where Salary.Eno=Eno and to_char(OverDate,'mm’')=to_char(GrantDate,'mm'));
update Salary set OverCost=0 where OverCost is null;
commit;
end ;
--录入福利总额
create or replace procedure Calculate_Welfare
is
begin
update Salary
set Welfaretotal=
(select WelfareTota from Welfare
where Salary.Eno=Eno and to_char(StatisticMonth,'mm')=to_char(GrantDate,'mm'));
update Salary set Welfaretotal=0 where Welfaretotal is null;
commit;
end Calculate_Welfare;
--录入迟到扣费
create or replace procedure Calculate_LateCost
is
begin
update Salary
set LateCost=
( select LateCost from AttendRecord
where Salary.Eno=Eno and to_char(StatisticMonth,'mm')=to_char(Grantdate,'mm'));
update Salary set LateCost =0 where LateCost is null;
commit;
end Calculate_LateCost;
--录入个人所得税
create or replace procedure Calculate_Tax
is
begin
--月收入低于1500
update Salary
set Tax=(BasicSalary+OverCost+Welfaretotal-LateCost)*0.03
where (BasicSalary+OverCost+Welfaretotal-LateCost)<1500;
--月收入在1500和4500之间
update Salary
set Tax=(BasicSalary+OverCost+Welfaretotal-LateCost-1500)*0.1+1500*0.03
where (BasicSalary+OverCost+Welfaretotal-LateCost) > 1500 and (BasicSalary+OverCost+Welfaretotal-LateCost)<=4500;
commit;
end;
--实发金额
create or replace procedure Calculate_RealSalary
is
begin
update Salary
set RealSalary=(BasicSalary+OverCost+Welfaretotal-LateCost)-Tax ;
commit;
end Calculate_RealSalary;
/。

相关文档
最新文档