作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 3 个这样的 JPA 实体以及相应的 JPA 存储库。
@Entity
public class ChairEntity {
...
@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true)
@JoinTable(name = "chair_image")
private Set<ImageEntity> images = new HashSet<>();
...
}
@Entity
public class TableEntity {
...
@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true)
@JoinTable(name = "table_image")
private Set<ImageEntity> images = new HashSet<>();
...
}
@Entity
public class ImageEntity{
...
private String description;
@Lob
private byte[] data;
...
}
使用 REST-API 创建和更新这些对象。这通常工作得很好,例如我可以像这样一次添加多个 imageEntities (所有代码块都在它们自己的事务中)
chairEntity.getImages().add(new ImageEntity(..));
chairEntity.getImages().add(new ImageEntity(..));
chairRepository.save(chairEntity);
...或一次更新同一个 chairEntity 的多个 ImageEntities。
chairEntity.getImages().stream().forEach(imageEntity -> {
imageEntity.setDescription("some other description");
}
chairRepository.save(chairEntity);
在这两种情况下,所有更改都会成功级联并保存。
但是,如果我更新现有的 ImageEntity 并添加另一个实体,则会失败:
chairEntity.getImages().stream().forEach(imageEntity -> {
imageEntity.setDescription("some other description");
}
chairEntity.getImages().add(new ImageEntity(...));
chairRepository.save(chairEntity); // crashes
异常如下(使用 h2db 会引发等效错误):
org.postgresql.util.PSQLException: ERROR: duplicate key value violates unique constraint "chair_image_pkey"
在检查 DB-Log 时,Hibernate 似乎正在尝试:
为什么会发生这种情况以及如何解决?在同一事务中单独保存和刷新更改似乎也不起作用。
最佳答案
解决方法,以防其他人遇到此问题:反转操作顺序:
chairEntity.getImages().add(new ImageEntity(...));
chairRepository.saveAndFlush(chairEntity);
chairEntity.getImages().stream().forEach(imageEntity -> {
imageEntity.setDescription("some other description");
}
chairRepository.save(chairEntity); // crashes
hibernate执行SQL语句的顺序保持不变,但由于之间的刷新,错误插入到Join表中的情况不再发生。
关于java - Hibernate ElementCollection/JoinTable IntegrityConstraintViolationException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59652322/
我从控制台收到此错误消息 com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate e
我有 3 个这样的 JPA 实体以及相应的 JPA 存储库。 @Entity public class ChairEntity { ... @OneToMany(cascade = Casca
我是一名优秀的程序员,十分优秀!