事务与触发器A

事务:具有统一性的过程。

可以添加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采用先操作内存表,然后实现真正操作。

 OLDNEW
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;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值