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

标签 java database database-design jpa-2.0

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

我们有这三个表:产品(id,代码,名称,描述,价格);已售产品(id,数量,product_id);订单(ID、日期、状态、评论)。

这是我们的问题:当我们从产品表中删除产品时,我们在 sellproducts 中遇到约束问题,因为 Product_id 列引用了产品。我们想要删除产品,但我们想要访问产品详细信息。

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

您认为针对这种特定情况的最佳设计方法是什么?

最佳答案

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

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

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

相关文章:

InnoDB 中的 MySQL 事务

sql - mysql中未读消息的数据库设计?

mysql - 物理集群 MYSQL 表以获得更好的性能

java - Android DatePickerDialog 参数

java - 为什么我收到错误?

java - JAVA中一维数组转换为二维数组

database - 具有 2 个不同所有者实体的弱实体

java - SWT 片段2。表排序。 items 数组在循环中发生变化。这是如何运作的?

iPhone Core Data 不刷新表格

database - 直接访问内容数据库 - SharePoint