mysql触发器例子

场景

由于旧表改造,许多表没有加修改时间,现在需要每条数据修改时能同时更新更新时间字段,通过修改实体类比较多、xml、sql等比较繁琐,并且容易出现遗漏,于是考虑通过触发器解决,网上搜索的大部分不能使用,现提供一个可以使用的创建触发器sql

1
2
3
4
5
6
CREATE TRIGGER 触发器名称
    BEFORE UPDATE on 表名
    for EACH ROW
BEGIN
    set NEW.update_time = NOW();
END;

 创建完成后通过

1
SHOW TRIGGERS

 查看所以触发器情况

 关键字解释:

MySQL 中定义了 NEW 和 OLD,用来表示触发器所在的表中,操作的那一行数据前后变化状态,表示新数据和原数据,具体地:

  ①在INSERT型触发器中,NEW用来表示将要(BEFORE)或已经(AFTER)插入的新数据

  ②在UPDATE型触发器中,OLD用来表示将要或已经被修改的原数据,NEW用来表示将要或已经修改为的新数据

  ③在DELETE型触发器中,OLD用来表示将要或已经被删除的原数据

posted on   qqq9527  阅读(117)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示