【发布时间】:2019-09-02 03:25:53
【问题描述】:
我有三个类,用户和产品,以及它们的关联类订单。我希望能够通过编辑用户或产品中的集合来添加和删除关联表中的行。添加工作正常,但是当我从例如删除一些订单时用户,它们保存在数据库中。
在this example 之后,我想出了这段代码。
@Getter
@Setter
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String username;
@OneToMany(mappedBy = "user", cascade = CascadeType.ALL)
private Set<Order> orders;
public void setOrders(Set<Order> orders) {
this.orders = orders;
orders.forEach(order -> order.setUser(this));
}
}
@Getter
@Setter
@Entity
public class Product {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
@OneToMany(mappedBy = "product", cascade = CascadeType.ALL)
private Set<Order> orders;
public void setOrders(Set<Order> orders) {
this.orders = orders;
orders.forEach(order -> order.setProduct(this));
}
}
和关联类:
@Getter
@Setter
@Entity
@NoArgsConstructor
public class Order {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@NotNull
@ManyToOne
@JoinColumn
private Product product;
@NotNull
@ManyToOne
@JoinColumn
private User user;
public Order(User user, Product product) {
this.user = user;
this.project = project;
}
@Override
public boolean equals(Object o){
if (this == o) return true;
if (!(o instanceof Order)) return false;
Engagement that = (Order) o;
return Objects.equals(user.getUsername(),
that.user.getUsername()) &&
Objects.equals(product.getName(),
that.product.getName());
}
@Override
public int hashCode(){
return Objects.hash(user.getUsername(),
product.getName());
}
}
在我的 OrderService 类中,我像这样添加和编辑一组订单:
public addProductsToUser(User user, Set<Product> products){
Set<Order> orders = products.stream().map(product -> new Order(user, product)).collect(Collectors.toSet());
user.setOrders(orders);
userRepository.save(user); //save from CrudRepository
}
我希望当我更新用户时它也会更新订单,以便不再引用的订单将被删除,但我得到了多个订单条目。
【问题讨论】:
标签: java mysql spring hibernate jpa