送分问题(第一次在ORCLE中写触发器),如何解决语法错误!

AlexGL 2003-12-19 11:11:13
我想把表Email_Sender 的最后一条记录插入表Email_Receive中,语句如下,但是总是报错,麻烦各位高手指点迷津。:)


Create Trigger ins_EmailSend

after insert on Email_Sender
FOR EACH ROW
Begin
Insert Into Email_Receive (EmailId,Receiever,Sender,Title,New,Content,Date,Memo)
Select EmailId,Receiever,Sender,Title,'0',Content,Date,Memo
From inserted
End Insert_checking
...全文
54 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
zgh2003 2003-12-19
  • 打赏
  • 举报
回复
执行前与执行后插入表Email_Receive有什么区别呢?
既然你想取插入值,触发前与触发后执行插入动作都一样嘛!
但是oracle中带插入操作的触发器,不管是before insert 或after insert
而得到的:old均为空值,所以必须before insert,而且只能取:new.colname。
另外,如果插入操作失败,触发器也不会把错误值插入表Email_Receive中。
njypch 2003-12-19
  • 打赏
  • 举报
回复
对触发器而言, 你所说的最后一条记录是不存在的,自然也不能达到你要的结果.只能采用其它办法了.
AlexGL 2003-12-19
  • 打赏
  • 举报
回复
抱歉,带到Orcle中执行时有编译错误,还有啊,FOR EACH ROW,应该是针对每一行,我想,我要插入的就是最后一条记录,不需要兴师动众吧,我是菜鸟,刚刚装好Orcle,在学习中,希望大侠们能够给我指点迷津,谢谢!来者有分!!
AlexGL 2003-12-19
  • 打赏
  • 举报
回复
谢谢楼上解释,我来试一试。:)
leecooper0918 2003-12-19
  • 打赏
  • 举报
回复
1.Oracle没有inserted这个虚表,估计你以前写过mssql 的触发器.

2.既然是后触发,那就使用after insert,注意不能用:new.colname,
要改成:old.colname.
AlexGL 2003-12-19
  • 打赏
  • 举报
回复
大侠,请问你为什么用before insert ?我想是在Email_Sender表记录插入后,然后再将Email_Sender中的最后一条记录插入到Email_Receive表中?我是菜鸟,希望你能够帮我,谢谢。:)
zgh2003 2003-12-19
  • 打赏
  • 举报
回复
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;
leecooper0918 2003-12-19
  • 打赏
  • 举报
回复
世纪飞扬说的是对了,我弄错了,只有update和delete操作时
才会用到.old。

17,377

社区成员

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

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