oracle 停止触发器语句,oracle触发器语句

ORACLE中触发器的判断IF语句

加一行 NULL 即可例如:SQL> DECLARE 2 testvalue INT; 3 BEGIN 4 testvalue := 200; 5 6 IF testvalue > 100 THEN 7 8 ELSIF testvalue = 100 THEN 9 dbms_output.put_line( '100' ); 10 ELSE 11 dbms_output.put_line( '100-' ); 12 END IF; 13 14 END; 15 / ELSIF testvalue = 100 THEN *ERROR 位于第 8 行:ORA-06550: 第 8 行, 第 9 列:PLS-00103: 出现符号 "TESTVALUE"在需要下列之一时::= . ( @% ;ORA-06550: 第 14 行, 第 4 列:PLS-00103: 出现符号 ";"在需要下列之一时:if上面的例子, 可以看出,如果 IF ELSE 里面, 没有内容, 那么编译不通过。

下面是 加一行 NULL 通过的例子:SQL> DECLARE 2 testvalue INT; 3 BEGIN 4 testvalue := 200; 5 6 IF testvalue > 100 THEN 7 NULL; 8 ELSIF testvalue = 100 THEN 9 dbms_output.put_line( '100' ); 10 ELSE 11 dbms_output.put_line( '100-' ); 12 END IF; 13 14 END; 15 /PL/SQL 过程已成功完成。

按照触发方式,oracle的触发器分为语句级和行级两种类型,在视图上

DML触发器有三类:1, insert触发器;2, update触发器;3, delete触发器;触发器的组成部分: 触发器的声明,指定触发器定时,事件,表名以类型 触发器的执行,PL/SQL块或对过程的调用 触发器的限制条件,通过where子句实现类型: 应用程序触发器,前台开发工具提供的; 数据库触发器,定义在数据库内部由某种条件引发;分为: DML触发器; 数据库级触发器; 替代触发器;DML触发器组件:1,触发器定时2,触发器事件3,表名4, 触发器类型5, When子句6, 触发器主体可创建触发器的对象:数据库表,数据库视图,用户模式,数据库实例创建DML触发器: Create [or replace] trigger [模式.]触发器名 Before| after insert|delete|(update of 列名)On 表名[for each row]When 条件PL/SQL块For each row的意义是:在一次操作表的语句中,每操作成功一行就会触发一次;不写的话,表示是表级触发器,则无论操作多少行,都只触发一次;When条件的出现说明了,在DML操作的时候也许一定会触发触发器,但是触发器不一定会做实际的工作,比如when 后的条件不为真的时候,触发器只是简单地跳过了PL/SQL块;Insert触发器的创建:create or replace trigger tg_insertbefore insert on studentbegin dbms_output.put_line('insert trigger is chufa le 。

..');end;/执行的效果:SQL> insert into student2 values(202,'dongqian','f');insert trigger is chufa le 。..update表级触发器的例子:create or replace trigger tg_updatestudentafter update on studentbegin dbms_output.put_line('update trigger is chufale 。

..');end;/运行效果:SQL> update student set se='f';update trigger is chufale 。..已更新8行;可见,表级触发器在更新了多行的情况下,只触发了一次;如果在after update on student后加上For each row的话就成为行级触发器,运行效果:SQL> update student set se='m';update trigger is chufale 。

..update trigger is chufale 。..update trigger is chufale 。

..update trigger is chufale 。..update trigger is chufale 。

..update trigger is chufale 。..update trigger is chufale 。

..update trigger is chufale 。..已更新8行;:new 与: old:必须是针对行级触发器的,也就是说要使用这两个变量的触发器一定有for each row这两个变量是系统自动提供的数组变量,:new用来记录新插入的值,old用来记录被删除的值;使用insert的时候只有:new里有值;使用delete的时候只有:old里有值;使用update的时候:new和:old里都有值;可以这样使用: dbms_output.put_line('insert trigger is chufa dbms_output.put_line('new id is : '||:new.stui dbms_output.put_line('new name is : '||:new.st dbms_output.put_line('new se is : '||:new.se);可以这样从数据字典中查看一个表上有哪几个触发器:SQL> select trigger_name from user_triggers2 where table_name=upper('student');TRIGGER_NAME------------------------------TG_INSERTTG_UPDATESTUDENT带有:old变量的行级delete触发器:create or replace trigger tg_deletestudentbefore delete on studentfor each rowbegin dbms_output.put_line('old is: '||:old.stuid); dbms_output.put_line('old name: '||:old.stuname);end;/运行效果:SQL> delete from student;old is: 202old name: dongqianold is: 101old name: liudehuaold is: 102old name: lingqingxiaold is: 103old name: lichanggongold is: 104old name: zhenxiuwenold is: 1001old name: lilianjieold is: 1009old name: tongleifuckold is: 203old name: kfdjold is: 209old name: fuck已删除9行When的使用:如果在begin也就是说触发器的PL/SQL主体块执行前加上when(old.se='f')的话,DML操作照做不误,但是只会在删除Se='f'的那行的时候才会执行触发器的主体动作,执行效果:SQL> delete from student;old is: 209old name: fuck已删除9行; 这里虽然删了9行,但是只执行了一次触发器的主体,做为一个行级触发器;混合类型触发器:Inserting,deleting,updating三个谓词可以分别指示当前操作到底是哪个;create or replace trigger hunhetriggerbefore insert or update or delete on studentfor each rowbegin if inserting then dbms_output.put_line('insert le。

'); end if; if deleting then dbms_output.put_line('delete le 。

.'); end if;end;/插入的时候就自动判断当前动作为插入:SQL> insert into student values(303,'me','f');insert le。

。删除的时候就自动判断当前动作为删除:SQL> delete from student;delete le 。

。.注意,既然触发器内部的主体PL/SQL是语句,那么它同样也可以是插入删除操作而不一定只是dbms_output打印一些信息;这正是日志表的原理:在用户执行了DML语句的时候触发主体为插入日志表以记录操作轨迹的触发器;为什么用触发器? 当我们有两个表用来记录商品的出库入库情况,good_store用来记录库存的产品类别和数量,而good_out用来记录出库的产品类别和数量,那么每当我们出库的某个类别的产品一定数量的时候,我们应该在good_out中插入该产品的类别和出库数量,而同时也应该在good_store表中用update来更新库存的相应类别的产品。

ORACLE中触发器的判断IF语句

加一行 NULL 即可

例如:

SQL> DECLARE

2 testvalue INT;

3 BEGIN

4 testvalue := 200;

5

6 IF testvalue > 100 THEN

7

8 ELSIF testvalue = 100 THEN

9 dbms_output.put_line( '100' );

10 ELSE

11 dbms_output.put_line( '100-' );

12 END IF;

13

14 END;

15 /

ELSIF testvalue = 100 THEN

*

ERROR 位于第 8 行:

ORA-06550: 第 8 行, 第 9 列:

PLS-00103: 出现符号 "TESTVALUE"在需要下列之一时:

:= . ( @

% ;

ORA-06550: 第 14 行, 第 4 列:

PLS-00103: 出现符号 ";"在需要下列之一时:

if

上面的例子, 可以看出,如果 IF ELSE 里面, 没有内容, 那么编译不通过。

下面是 加一行 NULL 通过的例子:

SQL> DECLARE

2 testvalue INT;

3 BEGIN

4 testvalue := 200;

5

6 IF testvalue > 100 THEN

7 NULL;

8 ELSIF testvalue = 100 THEN

9 dbms_output.put_line( '100' );

10 ELSE

11 dbms_output.put_line( '100-' );

12 END IF;

13

14 END;

15 /

PL/SQL 过程已成功完成。

Oracle中触发器有几种,用法与SQL Server一样吗

ORACLE触发器有以下两类: 1 语句级(Statement-level)触发器,在CREATE TRIGGER语句中不包含FOR EACH ROW子句。

语句级触发器对于触发事件只能触发一次, 而且不能访问受触发器影响的每一行的列值。一般用语句级触发器处理有关引起触发器触发的SQL语句的信息——例如,由谁来执行 2 行级(Row-level)触发器,在CREATE TRIGGER语句中包含FOR EACH ROW子句。

行级触发器可对受触发器影响的每一行触发,并且能 够访问原列值和通过SQL语句处理的新列值。行级触发器的典型应用是当需要知道行的列值时,执行一条事务规则。

SQL Server支持两种类型的触发器: AFTER 触发器和INSTEAD OF 触发器。其中AFTER 类型触发器要求只有执行某一操作(INSERT UPDATE DELETE) 之后,触发器才被触发,且只能在表上定义。

可以为针对表的同一操作定义多个触发器。对于AFTER 触发器,可以定义哪一个触发器被最先触发,哪一个被最后触发,通常使用系统过程sp_settriggerorder 来完成此任务。

INSTEAD OF 触发器表示并不执行其所定义的操作(INSERT、 UPDATE、 DELETE),而仅是执行触发器本身。既可在表上定义INSTEAD OF 触发器,也可以在视图上定义INSTEAD OF 触发器,但对同一操作只能定义一个INSTEAD OF 触发器。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值