gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 08:11:34 25 4
gpt4 key购买 nike

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

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