我的数据库工资表里需要将员工等级修改后,员工的补贴也跟着发生变化,我想通过触发器实现该变化.
比如员工编号为G1A1,那么补贴则为50;员工编号为G1B2,补贴为40,我想通过建立触发器更改等级时表自动更新数据,请问代码怎么写啊,还是我要再创建一个等级列?...
比如员工编号为G1A1,那么补贴则为50;员工编号为G1B2,补贴为40,我想通过建立触发器更改等级时表自动更新数据,请问代码怎么写啊,还是我要再创建一个等级列?
展开
1个回答
展开全部
create trigger on 表
after update as
if update(等级属性)
begin
declare @主码 string
declare @等级 money(有几个等级就declare几个)
…
select @主码=(select 主码属性 from inserted)
select @等级=(select 等级属性 from inserted)
switch(@等级){
case 等级1:
update 表 set 等级补贴值属性=‘数据’where 主码属性=@主码;
break;
case 等级2:
……其余类似
}
after update as
if update(等级属性)
begin
declare @主码 string
declare @等级 money(有几个等级就declare几个)
…
select @主码=(select 主码属性 from inserted)
select @等级=(select 等级属性 from inserted)
switch(@等级){
case 等级1:
update 表 set 等级补贴值属性=‘数据’where 主码属性=@主码;
break;
case 等级2:
……其余类似
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |