牛奶烤馒头 2021-07-01 14:40 采纳率: 100%
浏览 17
已采纳

触发器中使用if函数,执行成功,但是结果没变化。急呀!实践课要交了!

我想要的触发器功能: 当有信息插入到UC表时,根据插入信息中的“座位类型”字段的值不同,更改列车表中相应的字段。 比如UC表中插入的一个座位类型为“二等座”的信息时,列车表中的二等座余票的值就减一。 注:我为了写窗体时方便,二等座余票用的是varchar类型。

UC表:

img

列车表:

img

这是我写的触发器:

create trigger new
on UC 
after insert
as begin
  declare @车次 varchar
  declare @座位类型 varchar
  select @车次=车次,@座位类型=座位类型 from inserted 
  if(@座位类型='二等座')
  begin
    update 列车 set 二等座余票=二等座余票-1 where 车次=@车次
  end
  if(@座位类型='一等座')
  begin
    update 列车 set 一等座余票=一等座余票-1 where 车次=@车次
  end
  if(@座位类型='无座')
  begin
    update 列车 set 无座余票=无座余票-1 where 车次=@车次
  end
  end
  • 写回答

1条回答 默认 最新

  • 404警告 2021-07-01 14:48
    关注

    你这用中文就很怪 可能是没取到值尝试一下把=后的中文字段换成convert(int,'无座余票或者什么'), 把if换成case when好一点 if好像也是需要end的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度