事务与触发器A
来源:互联网 发布:淘宝规蜜怎么进入 编辑:程序博客网 时间:2024/06/05 20:30
事务:具有统一性的过程。
可以添加FOR UPDATE来限制并发更新。
主要由COMMIT和ROLLBACK组成,他们不可同时有序执行。
触发器: 不允许有参数。对于表加上约束,审计表的信息。
数据操作源触发器,它建立在表的基础之上。
行级触发器:例如创建删除触发器-
>CREATE OR REPLACE TRIGGER T_DEL_DEPART(此为触发器名称)
AFTER DELETE ON T_DEPARTMENT(on后为涉及的表名)
FOR EACH ROW
BEGIN
DELETE FROM V_TEST WHERE ID=:old.id;(特殊的写法)
END T_DEL_DEPART;
如果删除T_DEPARTMENT,那么就会删除V_TEST 的相应信息。
插入触发器:
>CREATE OR REPLACE TRIGGER T_INS_DEPART
AFTER INSERT ON T_DEPARTMENT
FOR EACH ROW
BEGIN
--注意NEW的写法
INSERT INTO V_TEST(ID) VALUES (:NEW.ID);
END T_INS_DEPART;
两个重要的内存表。oracle采用先操作内存表,然后实现真正操作。
OLD NEW INSERT 不可用 可用 DELETE 可用 不可用 UPDATE 可用 可用
更新触发器>CREATE OR REPLACE TRIGGER T_UP_DEPART
AFTER UPDATE ON T_DEPARTMENT
FOR EACH ROW
BEGIN
UPDATE V_TEST SET ID=:NEW.ID WHERE ID=:OLD.ID;
END T_UP_DEPART;
触发器中不可以用COMMIT和ROLLBACK语句。
但是可以采用如下的方式进行控制
CREATE OR REPLACE TRIGGER T_UP_DEPART
AFTER UPDATE ON T_DEPARTMENT
FOR EACH ROW
BEGIN
--采用一定的逻辑控制即可
IF :NEW.ID='3' THEN
RAISE_APPLICATION_ERROR(-20000,'HTY');
ELSE
UPDATE V_TEST SET ID=:NEW.ID WHERE ID=:OLD.ID;
END IF;
END T_UP_DEPART;
- 事务与触发器A
- 事务与触发器B
- 事务与触发器B
- oracle 触发器与事务
- 触发器事务
- 事务,触发器,存储过程
- 自治事务触发器问题解答
- 测试DBLINK触发器事务
- 事务日志& 表&触发器
- 触发器(自治事务)
- 了解触发器中事务
- 事务、触发器、视图、索引
- mysql事务视图触发器
- mysql之事务、触发器
- MySQL事务及触发器
- 存储过程-触发器-事务
- SQL Server触发器及触发器中的事务
- 触发器本身就是一个事务
- Ini文件的操作
- java真正入门大约需要多长时间呢.....
- CSDN 想说爱你不容易
- 微软Asp.net Ajax 1.0的AutoComplete控件的几处修正和增强
- COM原理及应用---- COM发展——COM+
- 事务与触发器A
- const in C++
- java中把String转换成Date的方法
- 【收藏】利用AJAX和ASP.NET实现简单聊天室
- 由ORM(Object Relation Mapping,对象关系映像)所想的
- 感动 - [人生随笔]2007-06-07
- 怎么用nc在两个机器中间传文件
- 感动 - [人生随笔]2007-06-07
- MSDN 书屋