如何利用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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
小李云雾1 天前
实际代码操作知识点分析:SQLAlchemy+FastAPI + 异步MySQL 全流程解析 + 增删改查逐行注释
数据库·mysql·fastapi
人道领域1 天前
【黑马点评日记】:用户签到功能详解——从Bitmap入门到避坑指南
java·数据库·redis·后端
Vect__1 天前
MySQL初识和基础操作
数据库·mysql
前进的李工1 天前
智能Agent实战指南:记忆组件嵌入技巧(记忆)
开发语言·前端·javascript·python·langchain·agent
西洼工作室1 天前
B站登录流程全解析:RSA+极验验证
前端·python·极验
zhaoyong2221 天前
如何在 MySQL 中实现基于全字段唯一性的重复行计数更新
jvm·数据库·python
X56611 天前
为什么宝塔面板网站无法正常连接外部远程数据库_检查服务器安全组放行端口并开启IP授权
jvm·数据库·python
woxihuan1234561 天前
C#怎么使用CancellationToken C#如何用取消令牌优雅地取消异步任务和长时间操作【进阶】
jvm·数据库·python
测试员周周1 天前
【AI测试功能5】AI功能测试的“黄金数据集“构建指南:从0到1搭建质量评估体系
运维·服务器·开发语言·人工智能·python·功能测试·集成测试
yexuhgu1 天前
MySQL主从复制支持跨版本吗_不同版本间同步的注意事项
jvm·数据库·python