行级触发器的问题

butian 2003-12-22 10:32:10
CREATE OR REPLACE TRIGGER "TABLET"."SETDATE" AFTER
INSERT
OR UPDATE ON "TABLET"."TEST" FOR EACH ROW
begin
update test
set d = sysdate
where a = new.a;
end ;


我知道行级触发器不能修改触发表,可是这个问题有什么解决的办法吗?
我只是想在本条记录添加或修改的时候,隐藏增加一个时间信息
...全文
66 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
butian 2003-12-22
  • 打赏
  • 举报
回复
解决了
多谢各位
放分
lianhg 2003-12-22
  • 打赏
  • 举报
回复
CREATE OR REPLACE TRIGGER SETDATE
BEFORE INSERT OR UPDATE
ON TEST
FOR EACH ROW
begin
if inserting then
:d :=sysdate;
elsif updating then
:d :=sysdate;
end if;
end;
iwantsay 2003-12-22
  • 打赏
  • 举报
回复
我在触发器里是这么写的。

:NEW.EDATE := Sysdate();

good luck
butian 2003-12-22
  • 打赏
  • 举报
回复
可以修改吗?
那为什么报04091错误啊?
多谢多谢~
lianhg 2003-12-22
  • 打赏
  • 举报
回复
行级触发器能修改触发表
iwantsay 2003-12-22
  • 打赏
  • 举报
回复
那你可以在before insert 的时候。

New.myDate := Sysdate;

就可以啦。

这时候不用写SQL更新数据的。

17,377

社区成员

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

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