Create Trigger ins_EmailSend
  before insert on Email_Sender 
  FOR EACH ROW
Begin
   Insert Into Email_Receive 
     (EmailId,Receiever,Sender,Title,New,Content,Date,Memo)    
     values(:new.EmailId,:new:Receiever,:new.Sender,:new.Title,'0',
     :new.Content,:new.Date,:newMemo);
End Insert_checking;

解决方案 »

  1.   

    大侠,请问你为什么用before insert ?我想是在Email_Sender表记录插入后,然后再将Email_Sender中的最后一条记录插入到Email_Receive表中?我是菜鸟,希望你能够帮我,谢谢。:)
      

  2.   

    1.Oracle没有inserted这个虚表,估计你以前写过mssql 的触发器. 2.既然是后触发,那就使用after insert,注意不能用:new.colname,
       要改成:old.colname.
      

  3.   

    抱歉,带到Orcle中执行时有编译错误,还有啊,FOR EACH ROW,应该是针对每一行,我想,我要插入的就是最后一条记录,不需要兴师动众吧,我是菜鸟,刚刚装好Orcle,在学习中,希望大侠们能够给我指点迷津,谢谢!来者有分!!
      

  4.   

    执行前与执行后插入表Email_Receive有什么区别呢?
    既然你想取插入值,触发前与触发后执行插入动作都一样嘛!
    但是oracle中带插入操作的触发器,不管是before insert 或after insert
    而得到的:old均为空值,所以必须before insert,而且只能取:new.colname。
    另外,如果插入操作失败,触发器也不会把错误值插入表Email_Receive中。
      

  5.   

    世纪飞扬说的是对了,我弄错了,只有update和delete操作时
     才会用到.old。