事务与触发器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;

 

原创粉丝点击