如何利用SQL触发器自动记录数据修改_编写审计日志逻辑

MySQL触发器中禁止对正在修改的表执行SELECT或INSERT操作,必须显式引用OLD/NEW字段;PostgreSQL的AFTER触发器必须返回NEW或OLD;审计时间应统一用CURRENT_TIMESTAMP并配合适当时区类型。MySQL 触发器里不能用 INSERT ... SELECT 直接读当前表想在 UPDATE 触发器里把旧值写进审计表,顺手写个 INSERT INTO audit_log SELECT OLD.id, OLD.name FROM t_user?会报错 ERROR 1442 (HY000): Can't update table 't_user' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.。MySQL 禁止触发器里再查或改自己正在被修改的表。实操建议:所有需要记录的字段,必须显式写出 OLD.col1、OLD.col2,不能用 SELECT * FROM ...如果字段多且常变,建议在应用层拼 SQL 或用视图预处理,别硬塞进触发器注意 OLD 在 INSERT 触发器里不可用,NEW 在 DELETE 触发器里不可用------写错类型直接报语法错误PostgreSQL 的 AFTER 触发器必须返回 NEW 或 OLDPostgreSQL 不像 MySQL 那样允许 AFTER 触发器只做日志不返回值。如果你写了个 AFTER UPDATE 触发器函数但末尾没写 RETURN NEW;,执行更新时会报 ERROR: trigger procedure did not return a value,而且整个事务会回滚。实操建议:BEFORE 触发器可修改 NEW 并返回它(比如自动更新 updated_at);AFTER 触发器只需返回原值即可,别漏掉函数体末尾统一加 RETURN NEW;(UPDATE/INSERT)或 RETURN OLD;(DELETE),哪怕你只记日志别在触发器里调 RAISE EXCEPTION 做业务校验------审计日志该记还得记,异常该抛还得抛,两者逻辑要分开审计字段时间戳要用 CURRENT_TIMESTAMP 而非 NOW()(尤其跨时区部署)很多触发器里写 INSERT INTO audit_log (...) VALUES (..., NOW(), ...),上线后发现日志时间比实际操作晚 8 小时。问题出在 NOW() 返回的是会话时区时间,而数据库服务器、应用服务器、客户端可能各有时区设置;CURRENT_TIMESTAMP 才是 SQL 标准定义的"语句开始时刻的 UTC 时间",配合 TIMESTAMP WITH TIME ZONE 类型才能真正对齐。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
tycooncool2 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
2401_837163892 小时前
golang如何编写SSL证书到期检测工具_golang SSL证书到期检测工具编写总结
jvm·数据库·python
Json____2 小时前
python-电商商城平台项目源码(管理端+用户端)
python·fastapi·电商商城·练习项目·wwwoop.com
m0_674294642 小时前
CSS如何实现左图右文布局_利用float属性与清除浮动
jvm·数据库·python
weixin_424999362 小时前
Bootstrap制作后台管理系统布局 Bootstrap如何搭建Dashboard框架
jvm·数据库·python
baidu_340998822 小时前
mysql表名大小写敏感问题如何处理_Lower Case Table Names设置
jvm·数据库·python
m0_674294642 小时前
TensorFlow如何监控内存使用情况_结合tf.summary记录关键指标信息
jvm·数据库·python
一 乐2 小时前
房产租赁管理|基于springboot + vue房产租赁管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·房产租赁管理系统
2301_815279522 小时前
c++ 游戏性能分析telemetry c++如何设计一个遥测系统
jvm·数据库·python