【发布时间】:2011-01-02 04:21:31
【问题描述】:
每次我需要设计一个新的数据库时,我都会花费一些时间 思考我应该如何设置数据库模式以保留审计日志 变化。
这里已经提出了一些关于此的问题,但我不同意 所有场景都有一个最佳方法:
- Database Design For Revisions
- Best design for a change log auditing database table
- Ideas on database design for capturing audit trails
我还偶然发现了这个interesting article on Maintaining a Log of Database Changes,它试图列出每种方法的优缺点。它写得很好,包含有趣的信息,但它让我的决定更加困难。
我的问题是: 有没有我可以使用的参考资料,可能是一本书或类似决策树之类的东西,我可以参考这些参考资料来决定我应该走哪条路 输入变量,例如:
- 数据库架构的成熟度
- 如何查询日志
- 需要重新创建记录的概率
- 更重要的是:写入或读取性能
- 正在记录的值的性质(字符串、数字、blob)
- 可用存储空间
我知道的方法是:
1.为创建和修改日期和用户添加列
表格示例:
- 身份证
- value_1
- value_2
- value_3
- 创建日期
- 修改日期
- created_by
- modified_by
主要缺点:我们丢失了修改的历史。提交后无法回滚。
2。仅插入表格
- 身份证
- value_1
- value_2
- value_3
- 来自
- 到
- 已删除(布尔值)
- 用户
主要缺点:如何使外键保持最新?需要很大的空间
3.为每个表创建一个单独的历史表
历史表示例:
- 身份证
- value_1
- value_2
- value_3
- value_4
- 用户
- 已删除(布尔值)
- 时间戳
主要缺点:需要复制所有已审核的表。如果架构发生变化,也需要迁移所有日志。
4.为所有表创建合并历史表
历史表示例:
- 表名
- 字段
- 用户
- 新值
- 已删除(布尔值)
- 时间戳
主要缺点:如果需要,我能否轻松地重新创建记录(回滚)? new_value 列需要是一个巨大的字符串,这样才能支持所有不同的列类型。
【问题讨论】:
-
用历史数据库代替表格怎么样?
-
也许你可以看看github.com/airblade/paper_trail的设计
-
按原样记录所有(必需)执行的查询是不是一个坏主意?
标签: database-design logging audit