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

createtrigger月工资变动afterupdateon考勤referencingoldrowasoldtuple,newrowasnewtupleforeachr... create trigger 月工资变动
after update on 考勤
referencing
oldrow as oldtuple,
newrow as newtuple
for each row
begin
if(oldtuple.一月份缺勤扣薪 != newtuple.一月份缺勤扣薪)
then
update 员工月工资 set 一月份工资=一月份工资-newtuple.一月份扣薪+oldtuple.一月份扣薪
where oldtuple.员工编号=员工月工资.员工编号;
end if;
end;
这是一个关于工资管理数据库的触发器,考勤是一个表,当考勤表中一月份缺勤扣薪改动时,员工工资表中对应的一月份工资变化,在SQL server中出现错误,请问错误在哪?
展开
 我来答
射手幽灵伊
推荐于2017-12-15 · TA获得超过2716个赞
知道大有可为答主
回答量:4955
采纳率:81%
帮助的人:1966万
展开全部

你这个写法是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
追问
好的,谢谢,刚试了试可以运行了,可能自己吧这两种语言弄混了吧=-=
SQL的艺术
2015-07-16 · SQL写多了就会在追求极致
SQL的艺术
采纳数:2040 获赞数:3323

向TA提问 私信TA
展开全部
if(oldtuple.一月份缺勤扣薪 != newtuple.一月份缺勤扣薪)
then

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

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

end if
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式