日期:2014-05-17  浏览次数:20879 次

触发器求教,请先生教我!
我公司有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亿的大表呢)
两表在其他上看不到有什么异同
难道有由程式新增的记录不触发触发器而在后台新增记录则可以触发呢?实在想不通,
还请各位先生教我!!!!!!!!!!!!!!!

------解决方案--------------------
你会不会是没有commit啊?
------解决方案--------------------
在这里的触发器里面不需要使用commit;

触发器是没有问题的,

smt.smtReduce_New

这是什么东西?

做触发器同步最容易出错的是类型不匹配,你检查一下好了,最好做一个exception处理表。
------解决方案--------------------
肯定会有的,你代码出问题了?

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

一致性读,触发器写入的肯定能查到的