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

DaJ*_*kal 2 java database database-design jpa-2.0

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

我们有这三个表:产品(id,代码,名称,描述,价格); soldproducts(id,quantity,product_id); 订单(ID,日期,状态,评论).

这是我们的问题:当我们从products表中删除产品时,我们在soldproducts中存在约束问题,因为product_id列引用了产品.我们想删除该产品,但我们希望能够访问产品详细信息.

我们希望在products表中添加一个aditional列,例如可用性,它告诉我们产品是否可用.使用这种方法,如果我们从应用程序中删除产品并且产品未从soldproducts引用,我们只是将此额外列更新为不可用,我们不会将其删除.否则,我们会从表中删除该产品.但我们不确定这是否是最佳方法.

您如何看待,针对这种情况,最佳设计方法是什么?

Pab*_*ruz 5

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

在我看到/工作的大多数系统中,这通常是在这种情况下完成的.当然,您需要每次都productsactive(非deleted)产品过滤您的查询.但这是不放弃历史数据参考的唯一方法.

  • 同意.这样,您的销售报告也不会搞砸. (2认同)