gpt4 book ai didi

java - JPA 对所有者的多对多合并触发对连接表的删除

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:26:10 25 4
gpt4 key购买 nike

我在 Customer 和 BusinessUnit 之间有多对多关系:

public class Customer extends AbstractEntity {

@JoinTable(name = "CUS_BUS_UNITS",
joinColumns = {
@JoinColumn(name = "CUS_ID", referencedColumnName = "CUS_ID")},
inverseJoinColumns = {
@JoinColumn(name = "BUS_ID", referencedColumnName = "BUS_ID")})
@ManyToMany
private Collection<BusinessUnit> businessUnits;
}

public class BusinessUnit extends AbstractEntity {

@ManyToMany(mappedBy = "businessUnits")
private Collection<Customer> customers;

}

当我调用 entityManager.merge(customer);在客户上(已经在数据库中,未更改)我在日志中看到这两个 sql 命令:

Hibernate: update CUSTOMERS set CUS_DESCR=?, CUS_NAME=?, CUS_ENABLED=? where CUS_ID=? Hibernate: delete from CUS_BUS_UNITS where CUS_ID=?

为什么 hibernate 试图从连接表中删除一条记录?我只需要更新客户记录并可能更新连接表中的记录 - 取决于我是否添加或删除了客户的业务部门。不应更新、删除或插入业务单位。

编辑:我的 equals/hashCode 是(在 AbstractEntity 中定义):

public int hashCode() {
if (getId() != null) {
return getId().hashCode();
}
return super.hashCode();
}
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
AbstractEntity other = (AbstractEntity) obj;
if (getId() == null || other.getId() == null) {
return false;
}
if (!getId().equals(other.getId())) {
return false;
}
return true;
}

编辑 2形式的转换器:

@FacesConverter("businessUnitConverter")
public class BusinessUnitConverter implements Converter {

/**
* {@inheritDoc}
*/
@Override
public String getAsString(FacesContext context, UIComponent component, Object object) {
return ((BusinessUnit) object).getId().toString();
}


@Override
public Object getAsObject(FacesContext context, UIComponent component, String value) {
BusinessUnit businessUnit = new BusinessUnit();
businessUnit.setId(Long.parseLong(value));
return businessUnit;
}

}

最佳答案

我找到了答案:http://assarconsulting.blogspot.fr/2009/08/why-hibernate-does-delete-all-then-re.html

由于使用了 Collection(请参阅链接文章),此行为是正确的。我使用 Set 而不是 collection,它工作正常。

关于java - JPA 对所有者的多对多合并触发对连接表的删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14897067/

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