1

我有一些代码需要帮助调试,但我觉得如果我能让其中一个运行,我就能得到其余的(哦,我多么希望)。

create or replace 
trigger minimumwage
before insert or update on Employee
for each row
begin
if :new.Wage < 7.25 
then raise_application_error('-20000,Pay is below Texas minimum wage!');
end if;
end;
/

如果有帮助,我正在尝试在通过 sqlplus 在我学校服务器上运行的表上执行此操作。

4

2 回答 2

5

当您遇到错误时,指定什么错误总是有帮助的。raise_application_error触发器中的调用存在语法错误。该过程有两个参数,一个数字和一个字符串。您传入的是一个长字符串的单个参数。

create or replace trigger minimumwage
  before insert or update on Employee
  for each row
begin
  if :new.Wage < 7.25 
  then 
    raise_application_error(-20000,'Pay is below Texas minimum wage!');
  end if;
end;

WAGE假设您的表中有一列应该是有效的EMPLOYEE

于 2013-05-08T20:06:24.593 回答
0
create or replace trigger deny_dec_pu before update of PU on ARTICLE
 for each row
 declare     
 erreur_pu exception;
  begin

     *insert into erreur values ('Operation de MAJ',sysdate);*

      -- this intruction is never executec why ?          

  if (:new.pu < :old.pu) then
  raise erreur_pu ; 
 end if;
 exception 
 when erreur_pu then 
  Raise_application_error(-20100, 'rrrrrrrr', FALSE); 

 end;

/

于 2014-12-18T22:53:54.047 回答