Oracle触发器执行正确,但没有被触发 5
写了一个触发器,当表中插入数据时,更改信息,触发器编译没有错误,也正常插入数据,但是在插入数据后,触发器似乎没有执行,麻烦帮忙看下代码:createorreplacetr...
写了一个触发器,当表中插入数据时,更改信息,触发器编译没有错误,也正常插入数据,但是在插入数据后,触发器似乎没有执行,麻烦帮忙看下
代码:
create or replace trigger tri_p
after insert on f_cam_campaign
for each row
declare
pragma autonomous_transaction;
begin
update f_cam_campaign set campaign_status='05' where cam_start_date >sysdate
commit;
end; 展开
代码:
create or replace trigger tri_p
after insert on f_cam_campaign
for each row
declare
pragma autonomous_transaction;
begin
update f_cam_campaign set campaign_status='05' where cam_start_date >sysdate
commit;
end; 展开
3个回答
2016-01-31 · 百度知道合伙人官方认证企业
育知同创教育
1【专注:Python+人工智能|Java大数据|HTML5培训】 2【免费提供名师直播课堂、公开课及视频教程】 3【地址:北京市昌平区三旗百汇物美大卖场2层,微信公众号:yuzhitc】
向TA提问
关注
展开全部
Oracle触发器执行正确,是因为触发时间不对或者基础表中没有满足条件的数据。
例如:
CREATE OR REPLACE TRIGGER CALCULA_IMC
AFTER INSERT OR UPDATE OF U_ALTURA, U_PESO ON UTILIZADOR
FOR EACH ROW
BEGIN
:NEW.U_IMC = (:NEW.U_PESO / 1000) / (POWER(:NEW.U_ALTURA / 100,2));
END;
/
例如:
CREATE OR REPLACE TRIGGER CALCULA_IMC
AFTER INSERT OR UPDATE OF U_ALTURA, U_PESO ON UTILIZADOR
FOR EACH ROW
BEGIN
:NEW.U_IMC = (:NEW.U_PESO / 1000) / (POWER(:NEW.U_ALTURA / 100,2));
END;
/
展开全部
不知道你的触发器什么作用
是不是该这么样:
create or replace trigger tri_p
after insert on f_cam_campaign
for each row
begin
update f_cam_campaign set campaign_status='05' where :new.cam_start_date >sysdate ;
end;
是不是该这么样:
create or replace trigger tri_p
after insert on f_cam_campaign
for each row
begin
update f_cam_campaign set campaign_status='05' where :new.cam_start_date >sysdate ;
end;
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
触发器里不要commit
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询