请问SQL server2008r2触发器怎么写?看了半天没个例子,不容易明白!

2025-01-18 18:57:04
推荐回答(2个)
回答1:

你这个写法是oracle的。sqlserver没有for each row也没有referencing。

create trigger 月工资变动
on 考勤
after update 
begin
declare @一月份缺勤扣薪_old numeric(10,4)
declare @一月份缺勤扣薪_new numeric(10,4)
declare @员工编号 int

if update(一月份缺勤扣薪)
begin
   select @一月份缺勤扣薪_old = 一月份缺勤扣薪 from deleted
   select @一月份缺勤扣薪_new = 一月份缺勤扣薪,@员工编号 = 员工编号 from inserted
   if( @一月份缺勤扣薪_old != @一月份缺勤扣薪_new )
      update 员工月工资 set 一月份工资 = 一月份工资 - b.一月份扣薪 + c.一月份扣薪 
  from 员工月工资 a,inserted b,deleted
  where a.员工编号=b.员工编号 and a.员工编号 = c.员工编号
end

回答2:

if(oldtuple.一月份缺勤扣薪 != newtuple.一月份缺勤扣薪)
then

end if;
这句话语法错了
标准语法是:
if (表达式判断)
begin

end
而不是
if (表达式判断) then

end if