我有一个 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/