加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-13 16:32:45 所属栏目:百科 来源:网络整理
导读:你能分享一下你在PostgreSQL中如何实现数据版本控制的想法. (我已经询问了有关 Cassandra和 MongoDB的类似问题.如果您有任何想法,哪个db更好,请分享) 假设我需要一个简单的通讯录中的版本记录.地址簿记录存储在一个表中,为了简单起见没有关系.我期望的历史:
你能分享一下你在PostgreSQL中如何实现数据版本控制的想法. (我已经询问了有关 Cassandra和 MongoDB的类似问题.如果您有任何想法,哪个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的变化,所以你有一个实际的版本.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读