上帝的骰子606 2022-02-15 15:36 采纳率: 25%
浏览 25
已结题

MySQL 触发器未实现功能

背景

初学mysql,按照书上写了代码

代码

-- 创建触发器的代码
create trigger update_vendor before update on vendors
for each row set new.vend_state=Upper(new.vend_state);

这个代码想实现插入州名时,无论大小写都会让州名变成大写

--- 插入代码
insert into vendors
values (1007,'Jk L','11 Main Street','SouthField','mi','44444','USA');

结果

img

第七行的 vend_state 没有变成大写 还是 'MI'

  • 写回答

3条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-02-15 16:35
    关注

    因为你触发器监视的是update 动作,而不是insert动作,因此插入并不会触发,
    before update on 应该改成 after insert on ,才会在插入之后触发

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月26日
  • 已采纳回答 2月18日
  • 创建了问题 2月15日

悬赏问题

  • ¥30 vb net 使用 sendMessage 如何输入鼠标坐标
  • ¥200 求能开发抖音自动回复卡片的软件
  • ¥15 关于freesurfer使用freeview可视化的问题
  • ¥100 谁能在荣耀自带系统MagicOS版本下,隐藏手机桌面图标?
  • ¥15 求SC-LIWC词典!
  • ¥20 有关esp8266连接阿里云
  • ¥15 C# 调用Bartender打印机打印
  • ¥15 我这个代码哪里有问题 acm 平台上显示错误 90%,我自己运行好像没什么问题
  • ¥50 C#编程中使用printDocument类实现文字排版打印问题
  • ¥15 找会编程的帅哥美女 可以用MATLAB里面的simulink编程,用Keil5编也可以。