【发布时间】:2019-06-08 14:56:16
【问题描述】:
我有以下三个实体EntityA、EntityB和EntityC:
实体A:
import lombok.*;
import javax.persistence.*;
import java.util.HashSet;
import java.util.Set;
@Entity
@Table(name = "Entity_A")
@Getter
@Setter
@Builder
@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode(of = "locationA")
@ToString(of = "locationA")
public class EntityA {
@Id
@Column(name = "Name_A", length = 10)
private String nameA;
@Column(name = "Loc_A", length = 10)
private String locationA;
@ManyToMany(cascade = { CascadeType.MERGE })
@JoinTable(
name = "En_A_On_B",
joinColumns = { @JoinColumn(name = "Name_A") },
inverseJoinColumns = { @JoinColumn(name = "B_id") }
)
private Set<EntityB> bs;
}
实体B:
import lombok.*;
import javax.persistence.*;
import java.util.HashSet;
import java.util.Set;
@Entity
@Table(name = "Entity_B")
@Setter
@Getter
@Builder
@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode(of = "locationB")
@ToString(of = "locationB")
public class EntityB {
@Id
@GeneratedValue
@Column(name = "B_id")
private int id;
@Column(name = "Loc_B", length = 10)
private String locationB;
@ManyToMany(cascade = { CascadeType.MERGE })
@JoinTable(
name = "En_C_on_B",
joinColumns = { @JoinColumn(name = "B_id") },
inverseJoinColumns = { @JoinColumn(name = "C") }
)
private Set<EntityC> cs;
}
实体C:
import lombok.*;
import javax.persistence.*;
import java.util.Set;
@Entity
@Table(name = "Entity_C")
@Getter
@Setter
@Builder
@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode(of = "c")
@ToString(of = "c")
public class EntityC {
@Id
@Column(name = "C", length = 20)
private String c;
}
要保存的服务类:
@Service
@Slf4j
public class ServiceClass {
@Autowired
private EntityARepository entityARepository;
private Set<EntityC> cs1 = new HashSet<>(asList(
EntityC.builder().c("100").build(),
EntityC.builder().c("10").build()
));
private Set<EntityC> cs2 = new HashSet<>(asList(
EntityC.builder().c("100").build(),
EntityC.builder().c("200").build()
));
//METHOD TO SAVE
public void save() {
Map<String, Set<EntityC>> map = new HashMap<>();
map.put("B1", cs1);
map.put("B2", cs2);
List<String> bs = asList("B1", "B2");
EntityA aa = EntityA.builder().nameA("abcd").locationA("mon").build();
EntityA ab = EntityA.builder().nameA("abcde").locationA("money").build();
bs.forEach(b -> {
EntityB entityB = EntityB.builder().locationB("100xxx").build()
entityB.getCs().addAll(map.get(b));
aa.getBs().add(entityB);
ab.getBs().add(entityB);
});
entityARepository.save(aa);
entityARepository.save(ab);
}
}
执行上述代码会引发以下异常
原因:java.lang.IllegalStateException:正在合并同一实体 [com.xxx.xxx.xxx.xxx.EntityC#100] 的多个表示。分离:[(c=100)];分离:[(c=100)]
注意:我在互联网上进行了探索,但没有一个与我的场景匹配
知道如何解决这个问题
【问题讨论】:
-
您是否尝试更改级联类型(关于 CascadeType.MERGE ):stackoverflow.com/questions/26591521/…?
-
使用 Spring Boot 和 H2 数据库的代码可以正常工作。
-
我正在使用 mssql。它对我来说是抛出异常。
-
将
CascadeType.MERGE更改为CascadeType.ALL,看看发生了什么。 -
它正在抛出相同的异常
标签: java hibernate jpa many-to-many