触发器求教,请先生教我!

szhourj2 2012-01-15 11:20:05
我公司有MES程式,为完成一定的功能,需编写触发器,我在一个其他表作了测试,是OK的,
所以转移到正式表上,SQL如下:
CREATE or replace TRIGGER TR_TEST
after INSERT
ON sajet.g_Sn_Status
referencing OLD AS OLD NEW AS NEW
FOR EACH ROW
BEGIN
--IF (:NEW.PROCESS_ID=100007) or (:NEW.PROCESS_ID=100008) THEN
--smt.smtReduce_New(:NEW.WORK_ORDER,:NEW.SERIAL_NUMBER,:NEW.EMP_ID,:NEW.MODEL_ID,:NEW.PDLINE_ID);

--------------test sql--------------
for i in 1..10000 loop
INSERT INTO SAJET.jackson_smt_wo(WORK_ORDER)
VALUES('houruijie') ;
end loop;
--------------test sql--------------
--END IF;
END TR_TEST;
表sajet.g_Sn_Status不断由MES程式产生的新记录,但表SAJET.jackson_smt_wo中始终不见有新记录生成,
又在sql plus中手工insert into sajet.g_Sn_Status ,结果触发器触发了,SAJET.jackson_smt_wo表中
多了10000笔新记录,为什么会这样?之前测试OK的表是数据量非常少的小表,而sajet.g_Sn_Status
是多达1000多条记录的大表了(当然还有多达5、6亿的大表呢)
两表在其他上看不到有什么异同
难道有由程式新增的记录不触发触发器而在后台新增记录则可以触发呢?实在想不通,
还请各位先生教我!!!!!!!!!!!!!!!
...全文
101 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
szhourj2 2012-01-18
  • 打赏
  • 举报
回复
实在不好意思,我是负责ERP这块的,MES这块我只是帮忙写一些程式,我对表结构及数据来源不是很清楚,后来才知道,前面我说的“有新增数据而触发器不触发”实际上只是个错觉,当时只是一次又一次查询一个日期型的列来查看是否有新记录生成,结果其实那些记录不是新增的,而日期型的列是不停的更新的。再一次说句:不好意思了。后来触发器改为如下就OK了
CREATE or replace TRIGGER TR_TEST
after update
of process_id
ON sajet.g_Sn_Status
referencing OLD AS OLD NEW AS NEW
FOR EACH ROW
BEGIN
--IF (:NEW.PROCESS_ID=100007) or (:NEW.PROCESS_ID=100008) THEN
--------------test sql--------------
for i in 1..10000 loop
INSERT INTO SAJET.jackson_smt_wo(WORK_ORDER)
VALUES('houruijie') ;
end loop;
--------------test sql--------------
END IF;
END TR_TEST;
iqlife 2012-01-16
  • 打赏
  • 举报
回复
肯定会有的,你代码出问题了?

要不然你的数据库出问题了,数据库HANG住了?看看那ALERT日志有错误?

一致性读,触发器写入的肯定能查到的
renfengjun 2012-01-16
  • 打赏
  • 举报
回复
在这里的触发器里面不需要使用commit;

触发器是没有问题的,

smt.smtReduce_New

这是什么东西?

做触发器同步最容易出错的是类型不匹配,你检查一下好了,最好做一个exception处理表。
huangdh12 2012-01-15
  • 打赏
  • 举报
回复
你会不会是没有commit啊?

17,382

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧