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

解决方案 »

  1.   

    在这里的触发器里面不需要使用commit;触发器是没有问题的,

    smt.smtReduce_New

    这是什么东西?做触发器同步最容易出错的是类型不匹配,你检查一下好了,最好做一个exception处理表。
      

  2.   

    肯定会有的,你代码出问题了?要不然你的数据库出问题了,数据库HANG住了?看看那ALERT日志有错误?一致性读,触发器写入的肯定能查到的
      

  3.   

    实在不好意思,我是负责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;