首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > oracle >

触发器的写法,该如何解决

2014-04-30 
触发器的写法我的业务需求是,在tab1被插入前,判断,如果其中tab1.idnull,我就给他赋值100就这样简单啦我

触发器的写法
我的业务需求是,在tab1被插入前,判断,如果其中tab1.id=null,我就给他赋值=100
就这样简单啦

我的部分代码是


create or replace TRIGGER TBBIKECARDREC_BI 
BEFORE INSERT  on TBGUESTCARDREC 
begin

  if (TBGUESTCARDREC.ID = null) then--这里就开始报错啦,说不允许出现这个表名什么
   
    TBGUESTCARDREC.ID := gen_id(gen_cardrec_id,1);--这个gen_id其实是个序列,自增100的序列
  end if;
end;


请问大家,以上代码改如何改啊
[解决办法]
晕 你之前没写对。。
create or replace TRIGGER TBBIKECARDREC_BI
  BEFORE INSERT on TBGUESTCARDREC
  for each row
begin
  if :old.id is null then
    :new.id := gen_id(gen_cardrec_id, 1);
  end if;
end;

热点排行