mysql – 如何跟踪数据库表中多列的更改以进行审计?

这个问题已经多次回答:here,here和外部链接herehere.

我理解上述线程中描述的方法,我打算使用this方法.

但我在实施这一点时几乎没有什么基本疑虑.

在我的情况下,一行中的多个列可以同时更新,因此遵循正确的实现方式:

>找出操作类型(INSERT / UPDATE / DELETE)
>找出正在更新的列
>在更新之前阅读整行
>在Audit表中为每个要更改的列插入一行,包含旧值和新值(以及其他详细信息)
>更新表格

最佳答案
假设您使用的是最新版本的mySQL,我个人会使用triggers.

假设它们或多或少像我在其他产品(例如Oracle)中熟悉的那样工作,那么你的问题会变得更简单,因为你在行上放置了一个“更新”触发器并用它来更新每个字段的审计表你对…感兴趣.

可能需要注意的是:如果您的应用程序仅将数据库作为一个用户登录(例如,如果使用连接池,则是一种常见方法),记录实际用户身份可能会很棘手.

相关文章

在正式开始之前,我们先来看下 MySQL 服务器的配置和版本号信...
> [合辑地址:MySQL全面瓦解](https://www.cnblogs.c...
物理服务机的CPU、内存、存储设备、连接数等资源有限,某个时...
1 回顾 上一节我们详细讲解了如何对数据库进行分区操作,包括...
navicat查看某个表的所有字段的详细信息 navicat设计表只能一...
文章浏览阅读4.3k次。转载请把头部出处链接和尾部二维码一起...