事务:具有统一性的过程。
可以添加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;