每次我需要设计一个新的数据库时,我都会花相当多的时间思考我应该如何设置数据库模式来保存更改的审计日志。
这里已经提出了一些问题,但我不同意所有情况下都有一种最好的方法:
我还偶然发现了这篇关于维护数据库更改日志的有趣文章,它试图列出每种方法的优缺点。它写得很好,有有趣的信息,但它让我的决定变得更加困难。
我的问题是:有没有我可以使用的参考资料,也许是一本书或者像决策树这样的东西,我可以参考它来根据一些输入变量来决定我应该走哪条路,比如:
可用数据库模式的成熟度更重要的是:写入或读取正在记录的值(string,numbers,blobs)
我知道的方法是:
1.为created和modified date和user添加列
表示例:
主要缺点:我们丢失了修改的历史记录。提交后无法回滚。
2.仅插入表格
主要缺点:如何使外键保持最新?需要巨大的空间
3.为每个表创建一个单独的历史记录表
历史表示例:
主要缺点:需要复制所有已审核的表。如果架构发生变化,还需要迁移所有日志。
4.为所有表创建一个合并历史表
历史表示例:
主要缺点:如果需要,我可以轻松地重新创建记录(回滚)吗?new_value列需要是一个很长的字符串,这样它才能支持所有不同的列类型。
https://stackoverflow.com/questions/2015232
复制相似问题