每次我需要设计一个新的数据库时,我都会花很多时间思考我应该如何设置数据库模式以保留更改的审计日志。
这里已经提出了一些问题,但我不同意所有场景都有一个最佳方法:
我还偶然发现了这篇关于维护数据库更改日志的有趣文章,它试图列出每种方法的优缺点。它写得很好,信息也很有趣,但它让我的决定更加困难。
我的问题是:有没有我可以使用的参考资料,可能是一本书或类似决策树的东西,我可以参考这些参考资料,根据一些输入变量决定我应该走哪条路,比如:
- 数据库模式的成熟度
- 如何查询日志
- 需要重新创建记录的概率
- 更重要的是:写入或读取性能
- 正在记录的值的性质(字符串、数字、blob)
- 可用存储空间
我知道的方法是:
1.添加创建和修改日期和用户的列
表格示例:
- ID
- 值_1
- 价值_2
- 值_3
- 创建日期
- 修改日期
- 由...制作
- 修改者
主要缺点:我们丢失了修改的历史。提交后无法回滚。
2. 只插入表格
表格示例:
- ID
- 值_1
- 价值_2
- 值_3
- 从
- 至
- 已删除(布尔值)
- 用户
主要缺点:如何使外键保持最新?需要巨大的空间
3.为每个表创建一个单独的历史表
历史表示例:
- ID
- 值_1
- 价值_2
- 值_3
- value_4
- 用户
- 已删除(布尔值)
- 时间戳
主要缺点:需要复制所有已审计的表。如果架构发生更改,则也需要迁移所有日志。
4.为所有表创建一个合并历史表
历史表示例:
- 表名
- 场地
- 用户
- 新值
- 已删除(布尔值)
- 时间戳
主要缺点:如果需要,我能否轻松地重新创建记录(回滚)?new_value 列需要是一个巨大的字符串,以便它可以支持所有不同的列类型。