gpt4 book ai didi

sql - 以高效方式存储关系对象的修订

转载 作者:搜寻专家 更新时间:2023-10-30 20:07:01 26 4
gpt4 key购买 nike

我不确定之前是否有人回答过此类问题。在我的数据库中,我有一个产品表和规范表。每个产品可以有多个规范。在这里,我需要将每个产品的修订存储在数据库中,以便稍后查询它们以获取历史记录。

因此,我需要一种有效的方法来在用户每次更改这些关系时存储产品与规范的关系。数据量也会变得非常大。例如,假设数据库中有 100000 个产品:每个产品可以有 30 个规范,并且每个产品至少有 20 个修订。因此,通过将所有数据存储在一个表中,数据量变得非常大。

有什么建议吗?

最佳答案

如果这纯粹是为了“存档”目的,那么单独的修订表可能会更好。

但是,如果您需要将以前的修订与当前的修订同等对待(例如,如果您想让用户能够将产品恢复到以前的修订),那么最好保留一个产品表,而不是而不是在表之间复制数据。如果您担心性能,这就是索引的用途。

您可以为产品表创建复合主键,例如主键(product_id,修订版)。也许通过为特定 product_id 选择具有最高 revision 的行来查找当前修订的存储过程会很有用。

关于sql - 以高效方式存储关系对象的修订,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1762694/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com