CREATE OR REPLACE TRIGGER tr_INSERT_emp
AFTER INSERT--指定触发时机为更新操作后触发
ON T
FOR EACH ROW --说明创建的是行级触发器
BEGIN
UPDATE T SET B=:'B'
where A=:old.AEND;
-- 创建表
create table TTT(
a VARCHAR2(10),
b VARCHAR2(10)
);
-- 创建触发器
CREATE OR REPLACE TRIGGER tr_i_before_ttt BEFORE INSERT
ON TTT FOR EACH ROW
BEGIN
if :New.A = 'A' then
:New.B := 'B';
end if;
END;
/
-- 测试
insert into TTT(a, b) values ('A', 'C');
insert into TTT(a, b) values ('B', 'C');
-- 结果
sxdtgsh> select * from TTT;
A B
---------- ----------
A B -- 这个值在插入的时候是C,触发器已经改成B了。
B C
从你的问题看你对触发器的理解有问题~~