有什么办法可以让我们的程序中加载的实体的所有引用都用hibernate一次性更新?
例如,我在A类中加载了id为 "1 "的产品,然后在B类中更改了一个id为 "1 "的相同产品的新的加载,但是A类中的那个产品并没有改变,我应该如何解决这个问题?
这是部分代码。产品类 :
@Entity
@Table(name = "t_product")
public class Product {
@Setter(AccessLevel.NONE)
@Id @GeneratedValue @Column(name = "ID")
private int id;
...
@ElementCollection
@OneToMany(targetEntity = SellerIntegerMap.class,
fetch = FetchType.EAGER,
cascade = CascadeType.ALL)
@JoinTable(name = "t_product_stock")
private List<SellerIntegerMap> stock;
...
}
卖家IntegerMap 。
@Entity
@Table(name = "t_map")
public class SellerIntegerMap{
@Setter(AccessLevel.NONE)
@Id @GeneratedValue
private int id;
@ManyToOne
@JoinColumn(name = "SELLER")
private Seller seller;
@Column(name = "INTEGER_VALUE")
private Integer integer;
}
DBManager 。
public class DBManager {
public static <T> T load(Class<T> type, Serializable serializable){
Session session = HibernateUtil.getSession();
session.beginTransaction();
T object = session.get(type,serializable);
if (object == null){
}
session.evict(object);
session.getTransaction().commit();
return object;
}
public static void save(Object object){
Session session = HibernateUtil.getSession();
session.beginTransaction();
session.saveOrUpdate(object);
session.getTransaction().commit();
}
}
和测试。
public void test(){
Product product = DBManager.load(Product.class,1);
Product productDup = DBManager.load(Product.class,1);
List<SellerIntegerMap> list = productDup.getStock();
list.get(0).setInteger(25);
DBManager.save(productDup);
}
数据在SQL表中更新,但在 "product "中没有更新,而 "product "和 "productDup "是同一个实体。
你需要一个事务覆盖整个操作。这样,Hibernate将只保留该实体的一个管理实例。