java - 当购物车被清除时,如何处理数据库中的购物车项目

标签 java jpa mapping shopping-cart

我有一个 ShoppingCart ,其中有一组 CartItem 对象。当我保存购物车时,所有购物车项目也会被保存。当买家确认购买时,我需要清除购物车。如果我现在将购物车保存到数据库,已经保存在数据库中并与购物车关联的购物车项目会发生什么?我应该从数据库中删除它们吗?

实体的 jpa 映射是

@Entity
class ShoppingCart{
...
   @OneToOne
   public Buyer buyer;

   @OneToMany(mappedBy="cart", cascade=CascadeType.ALL)
    public Set<CartItem> cartItems;
 ...
}

@Entity
public class CartItem{
   @ManyToOne
   public ShoppingCart cart;

@OneToOne
   public Product pdt;
   public int quantity;
...

} 
}

数据库中的购物车表

id  | buyer_id 
-----+-------------
 100 |   50

cartitem表可以

 id  | quantity | product_id | cart_id 
-----+----------+------------+---------
 12  |        2 |     234    |  100
--------------------------------------
 13  |       4  |     231    |  100

因此,在我清除购物车并将其保存到数据库后,如果这些商品仍在数据库中,则意味着购物车 12 仍然引用购物车 100。但是,id=100 的购物车没有购物车,因为我已经清除了它们。 那么,清除购物车并将其保存到数据库相当于删除购物车吗? 我该如何映射这种行为?或者我的想法有缺陷吗?

最佳答案

您还没有发布有关如何清理购物车的代码,因此我的回答将做出相当多的假设。

根据表格的内容,我假设您已在 ShoppingCart 类中调用了 cartItems.clear()。此调用的问题在于您的关系是双向的,因此 CartItem 实例将继续拥有对 ShoppingCart 实例的引用,尽管相反情况并非如此。根据您使用的 JPA 提供程序,清除 Set 并使用数据库更新持久性上下文内容将不会清除 cartitem 表,或者会抛出异常,指出cart_id 不能为空(如果您的外键不可为空)。

大多数 JPA 提供程序(尤其是 Hibernate)中的修复是清除 CartItem 实例中对 ShoppingCart 的引用以及 cartItems 的引用code> 在 ShoppingCart 中设置。请注意,如果您选择使用 orphanRemoval 删除孤立条目@OneToMany 注释的属性(自 JPA 2.0 起支持),那么所有孤立的 CartItems(未由 ShoppingCart 引用的)也将被清除双向关系后,在数据库中删除。如果没有将 orphanRemoval 属性设置为 true,您的 JPA 提供程序将不会尝试删除 ShoppingCart 不再引用的 CartItem;交易最终是否会成功取决于您在 cartitem 表中的外键是否可为空。

如果您打算在数据库中保留 CartItem 记录,但仅仅取消对 ShoppingCart 的引用,那么您应该将该引用指定为可空(使用@Column 注释,并且还定义表具有可为空的外键)。

关于java - 当购物车被清除时,如何处理数据库中的购物车项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7333681/

相关文章:

java - 不使用 Joda Time 的 Java 时间转换

java - While 循环和步骤

java - Jenkins 找不到通过 Eclipse 为 selenium 项目添加的外部 Jars

postgresql - JPA - Postgres - 如何使用 Distinct 和 Group By 从表中获取结果

java - Hibernate 在调用 save 后丢失了引用。你知道为什么吗?

java - RX Java Flowable 中的所有元素达到特定条件

hibernate - 带有参数的JPQL ORDER BY子句

java - EntityManager.merge() 对对象图中的所有实体发出 SELECT

python - 多态映射类型

mysql - 如何在Hibernate中映射Spring Security表