触发器:自动执行,可以实现表的约束。

1.行级触发器:  

CREATE OR REPLACE TRIGGER del_deptid
AFTER DELETE ON deptment --触发器条件 DELETE动作
FOR EACH ROW --循环每一行都改
BEGIN
DELETE FROM emp WHERE id=:old.id; --触发后动作
END del_deptid; --END;都行
/
DELETE FROM deptment WHERE id='';  --触发触发器
CREATE OR REPLACE TRIGGER insert_dept
AFTER INSERT ON deptment --触发器条件 INSERT动作
FOR EACH ROW --循环每一行都改
BEGIN
INSERT INTO emp(eid ,ename,id) VALUES('','qwer',:new.id); --触发后动作
END;
/
  old new
insert n y
delete y n
update y y

n为不涉及的

只有在创建触发器的时候会触及oracle的old和new逻辑表,old和new是oracle在内存中建立的表,表的字段结构和触发器所涉及的表的字段结构一致,对表操作时,先将要修改的内容保存在old和new中,commit后写到磁盘中,如删除表中的一条的数据,先将内存中该表的该条数据移动到old表中,插入是将要插入的数据先插入到new中,之后再插入到内存表中,更新是将where后的信息存入old,将set红的数据存入new中,其他不变字段就一样。

利用old和new表做级联更新:

CREATE OR REPLACE TRIGGER update_dept
AFTER UPDATE ON deptment
FOR EACH ROW
BEGIN
UPDATE emp SET id=:new.id WHERE id=:old.id;
END;
/ --不可以在语句块中写commit 和 rollback
UPDATE deptment SET id='yy' WHERE id='';
CREATE OR REPLACE TRIGGER book_delete
AFTER DELETE ON books
FOR EACH ROW
BEGIN
IF :old.books_id='' THEN --通过触发器实现控制
RAISE_APPLICATION_ERROR(-20000,'不允许删除!'); ---2000为错误代码
END IF;
END;
/

2.语句级触发器:

CREATE OR REPLACE TRIGGER dml_aa
AFTER INSERT OR DELETE OR UPDATE --可以是多个动作触发
BEGIN --没有for each row 没有数据完整性约束
IF INSERTING THEN
INSERT INTO mylog VALUES(user,sysdate,'I');
ELSIF DELETING THEN
INSERT INTO mylog VALUES(user,sysdate,'D');
ELSE
INSERT INTO mylog VALUES(user,sysdate,'U');
END IF;
END;
/

3.利用触发器实现表中整型字段的自增:

CREATE OR REPLACE TRIGGER set_no
BEFORE INSERT ON auto --前触发器,插入之前做一个预处理
FOR EACH ROW
DECLARE
sn number(5); --定义变量
BEGIN
SELECT myseq.nextval INTO sn FROM dual;--取出myseq序列的值,放入变量中
:NEW.a:=sn; --插入前,将sn的值赋给表中的a字段,NEW为触发器在内存中自动生成的和要处理的表字段结构一致的表,即auto表中的a字段,如果用向a字段。
END;
/

4.替换触发器:

有的视图是由两个表组成的,当视图是由两个或两个以上组成的是不允许同时更新的,而替换触发器可以解决这种视图的多表更新的,替换触发器在Oracle中只能建在视图上。

视图建立在员工表和部门表上,v_emp_dept;

当向视图中插入数据时会提示,每次只能更改一个表中的信息,用替换触发器解决此问题的方法。

CREATE OR REPLACE TRIGGER tr_v_e_d
INSTEAD OF INSERT ON v_emp_dept --替换向v_emp_dept 视图中插入数据的方法,分别向两个表中插入数据实现
FOR EACH ROW --替换触发器是特别的行触发器
BEGIN
INSERT INTO deptment VALUES(:new.id,:new.name);
INSERT INTO emp(eid,ename,sex,id) VALUES(:new.eid,:new.ename,:new.sex,:new.id);
END;
/

事物

修改表的时候如果不 commit 是不会修改的,虽然用查询语句查询会出现该条记录已被修改,但只是在内存中修改,用 rollback命令即可还原,只要没commit就没有修改该表。commit 是将内存中的数据写到磁盘上,rollback命令可还原上一个动作的的修改,一旦commit之后,就不可以rollback回来了,rollback之后也不可以commit了。

SELECT * FROM  dept FOR UPDATE;
这样在其他用户下就不可以修改该表,直到你修改之后,commit,别人才可以改,像是买票那个锁。

Oracle 触发器,事物的更多相关文章

  1. ORACLE 自治事物

    ORACLE 自治事物 一.问题 (1)现象   一个表A,存在一个触发器,该触发器用来统计表A的数量,并将结果更新到B表.此时,java代码里面调用insert into select 语句,会发生 ...

  2. 2014/11/06 Oracle触发器初步 2014-11-06 09:03 49人阅读 评论(0) 收藏

    触发器我就不多解释了,保证数据的完整性的神器,嗯..也是减少程序员工作托管给数据库操作的好帮手.就不讲一些大道理了.通俗点,我们对数据库的操作,无非就是增 删 改 查. 触发器就是在删,改,增的时候( ...

  3. oracle触发器加条件判断

    oracle触发器加条件判断,如果某个字段,isnode=0,那么不执行下面的方法,数据如下: create or replace trigger tr_basestation_insert_emp ...

  4. [转]连续创建多个Oracle触发器失败,单个创建才成功的解决方法

    连续创建多个Oracle触发器失败,单个创建才成功的解决方法   1.当我连续执行创建多个触发器时,总是报编译通过,但存在警告或错误.如下:   create or replace trigger t ...

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

    摘要: 本文讨论了利用数据库中的触发器对日志管理进行设计与实现的方法, 是对原来在客户端软件中编写日志管理方法的一种改进, 并给出了 Oracle9i 中的实例演示.关键词: Oracle; 触发器; ...

  6. oracle触发器应用

    首先给大家推荐两篇我看后的博文,我已经内容转载过来: 1.对触发器的讲解 本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建 ...

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

    1.通过Oracle序列 -- Create sequence create sequence SEQ_DW_EWSYSTEM minvalue 1 maxvalue 9999999999999999 ...

  8. SQL server与Oracle触发器的创建与使用

    SQL Server 1创建触发器 GO BEGIN IF (object_id('WMY', 'tr') is not null) DROP trigger WMY END; GO CREATE T ...

  9. oracle触发器中增删改查本表

    oracle触发器中增删改查本表 (1)只有before insert触发器中才可以查询或更新本表 create or replace trigger tri_test_ins before inse ...

  10. Oracle触发器用法实例详解

    转自:https://www.jb51.net/article/80804.htm. 本文实例讲述了Oracle触发器用法.分享给大家供大家参考,具体如下: 一.触发器简介 触发器的定义就是说某个条件 ...

随机推荐

  1. 转:Nginx+Apache环境的安装与配置

    转:http://www.server110.com/nginx/201404/8817.html 我们依然尽可能采用yum来安装我们需要的软件,由系统官方维护的软件,其安全性和稳定性都值得信赖,并且 ...

  2. BZOJ1736 [Usaco2005 jan]The Wedding Juicer 婚宴的榨汁机

    从外面一点一点往里面拓展(floodfill),每次找出最小的一个点,计算它对答案的贡献就好了... 找最小的点的话,直接pq就行 /********************************* ...

  3. svn resolve/merge

    svn merge http://svn.a.com/branches/20150129_168954_sales-impr_1 svn resolve --accept working web/sr ...

  4. 在Excel中引用其他宏

    在excel的使用过程中,会用到一些自定义函数,可以使用宏轻松的实现这些功能,问题是必须使用“启用宏的excel”,这样用户每次打开时都要启用宏. 现用以按背景色计划为例,解决以上问题: 1.新建一个 ...

  5. CRF++使用小结

    1. 简述 最近要应用CRF模型,进行序列识别.选用了CRF++工具包,具体来说是在VS2008的C#环境下,使用CRF++的windows版本.本文总结一下了解到的和CRF++工具包相关的信息. 参 ...

  6. SPOJ SUBLEX 求第k小子串

    题目大意: 对于一个给定字符串,找到其所有不同的子串中排第k小的子串 先构建后缀自动机,然后我们可以将整个后缀自动机看做是一个DAG图,那么我们先进行拓扑排序得到 *b[N] 对于每个节点记录一个sc ...

  7. SharePoint加K2,将Portal系统与BPM系统完美整合!

    K2 blackPearl与Microsoft Office SharePoint 一起为解决人员和流程相互合作的解决方案而提供一个强大的平台. K2“blackpearl”根据企业的需求提供了设计, ...

  8. Ubuntu根目录下各文件的功能介绍

    http://jingyan.baidu.com/article/afd8f4de55189c34e286e9e6.html

  9. OpenLayers简单介绍以及简单实例

    OpenLayers是一个强大的JavaScript包,可以从它的官网免费下载.OpenLayers包含了很多强大的网页地图展示与操作功能,并且能够将不同源的图层展示在同一张地图中,支持各种第三方的地 ...

  10. [转] lib和dll 区别,生成及使用方法

    lib 和 dll 的区别.生成以及使用详解 [目录] lib dll介绍 生成动态库 调用动态库 生成静态库 调用静态库 首先介绍一下静态库(静态链接库).动态库(动态链接库)的概念,首先两者都是代 ...