首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >用于审计日志记录的数据库设计

用于审计日志记录的数据库设计
EN

Stack Overflow用户
提问于 2010-01-07 02:27:40
回答 6查看 93.1K关注 0票数 166

每次我需要设计一个新的数据库时,我都会花相当多的时间思考我应该如何设置数据库模式来保存更改的审计日志。

这里已经提出了一些问题,但我不同意所有情况下都有一种最好的方法:

我还偶然发现了这篇关于维护数据库更改日志的有趣文章,它试图列出每种方法的优缺点。它写得很好,有有趣的信息,但它让我的决定变得更加困难。

我的问题是:有没有我可以使用的参考资料,也许是一本书或者像决策树这样的东西,我可以参考它来根据一些输入变量来决定我应该走哪条路,比如:

可用数据库模式的成熟度更重要的是:写入或读取正在记录的值(string,numbers,blobs)

  • 数据库模式的成熟度
  • 如何查询日志
  • 需要重新创建记录的概率
  • 更重要的是:写入或读取性能
  • 正在记录的值的性质(字符串、数字、blob)
  • 可用存储空间

我知道的方法是:

1.为created和modified date和user添加列

表示例:

  • id
  • 值_1
  • 值_2
  • 值_3
  • 创建日期
  • 修改日期
  • 创建者
  • 修改者

主要缺点:我们丢失了修改的历史记录。提交后无法回滚。

2.仅插入表格

表示例

  • id
  • 值_1
  • 值_2
  • 值_3
  • 已删除 (布尔值)
  • 用户

主要缺点:如何使外键保持最新?需要巨大的空间

3.为每个表创建一个单独的历史记录表

历史表示例:

  • id
  • 值_1
  • 值_2
  • 值_3
  • 值_4
  • 用户
  • 已删除 (布尔值)
  • 时间戳

主要缺点:需要复制所有已审核的表。如果架构发生变化,还需要迁移所有日志。

4.为所有表创建一个合并历史表

历史表示例:

  • 表名
  • 场地
  • 用户
  • 新值
  • 已删除(布尔值)
  • 时间戳

主要缺点:如果需要,我可以轻松地重新创建记录(回滚)吗?new_value列需要是一个很长的字符串,这样它才能支持所有不同的列类型。

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2015232

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档