gpt4 book ai didi

java - 我们数据库设计的最佳方法

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

我们有一个电子商务应用程序的数据库,我们正在使用 JPA 2.0。

我们有这三个表:products(id, code, name, description, price); soldproducts(id, quantity, product_id);订单(ID、日期、状态、评论)。

这是我们的问题:当我们从 products 表中删除一个产品时,我们在 soldproducts 中有一个约束问题,因为 product_id 列引用了一个产品。我们想删除产品,但我们想访问产品详细信息。

我们想在产品表中添加一个附加列,例如可用性,它告诉我们产品是否有货。使用这种方法,如果我们从应用程序中删除一个产品并且该产品不是从 soldproducts 中引用的,我们只是将这个额外的列更新为不可用,我们不会删除它。否则,我们从表中删除该产品。但我们不确定这是否是最佳方法。

您怎么看,对于这种情况最好的设计方法是什么?

最佳答案

在我看来,最好的设计方法是不删除产品行,而是将其标记为已删除。您需要向表中添加 deletedactive boolean 列。

这是我看到/使用过的大多数系统在这种情况下通常所做的事情。当然,您每次都需要按 Activity (而不是删除)产品过滤您的产品查询。但这是不丢失历史数据引用的唯一方法。

关于java - 我们数据库设计的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5133061/

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