微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

postgresql – 在PostreSQL中实现数据版本控制的方法

你能分享一下你在Postgresql中如何实现数据版本控制的想法. (我已经询问了有关 CassandraMongoDB的类似问题.如果您有任何想法,哪个db更好,请分享)

假设我需要一个简单的通讯录中的版本记录.地址簿记录存储在一个表中,为了简单起见没有关系.我期望的历史:

>将不经常使用
>将一次性使用,以“时间机”的形式呈现
>不会有更多的版本比几百到单个记录.
>历史不会过期.

我正在考虑以下方法

>创建一个新的对象表以存储具有地址簿表模式副本的记录历史记录,并将时间戳和外键添加到地址簿表中.
>创建一种减少表格以存储地址簿记录的更改.这样的表将包括:AddressBookId,TimeStamp,FieldName,Value.这样我只会将更改存储到记录中,我不必将历史表和地址簿表保持在同步状态.
>创建一个表来存储串行(JSON)地址簿记录或更改地址簿记录.这样的表格将如下所示:AddressBookId,Object(varchar).
再次,这是模式较少,所以我不必保持历史表与地址簿表同步.
(This is modelled after Simple Document Versioning with CouchDB)

我做类似于你的第二种方法:将表与实际的工作集和具有更改的历史(timestamp,record_id,property_id,property_value)相结合.这包括创建记录.第三个表格描述了属性(id,property_name,property_type),这有助于在应用程序中更高的数据转换.所以你也可以轻松跟踪单个属性的更改.

而不是一个时间戳,你也可以有一个类似的,你每增加一个record_id的变化,所以你有一个实际的版本.

原文地址:https://www.jb51.cc/postgresql/191738.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐