本网站上的类似问题都无法解决我的问题。
错误: org.hibernate.persistentObjectException:传递的分离实体传递给持久:healthcheckapi.model.model.checks
我正在尝试使用Hibernate(JPA(将两个对象持续到MySQL数据库。"健康"与"检查"有一致的关系。
代码:
健康课:
@Entity
@Table(name="health")
public class Health {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int id;
private String server;
private String description;
private String timestamp;
private String offset;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "health")
private List<Checks> checks;
public Health() {
}
public Health(int id, String server, String description, String timestamp, String offset, List<Checks> checks) {
this.server = server;
this.description = description;
this.timestamp = timestamp;
this.offset = offset;
this.checks = checks;
}
检查类:
@Entity
@Table(name="checks")
public class Checks {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int id;
private String name;
private int status;
@ManyToOne(cascade = CascadeType.ALL)
@JoinColumn(name = "healthid", referencedColumnName="id")
private Health health;
public Checks() {
}
public Checks(String name, int status) {
this.name = name;
this.status = status;
}
样本JSON健康对象:
{
"server": "Server18",
"description": "Fine",
"timestamp": "00:02:30",
"offset": "00:01:00",
"checks": [
{ "id": "1",
"name": "cpu",
"status": 90
},
{
"id": "2",
"name": "memory",
"status": 88
},
{
"id": "3",
"name": "apacheService",
"status": 76
}
]
}
请注意,两个对象的ID都是自动生成的,我认为这是问题的一部分。
使用CascadeType.MERGE
代替CascadeType.ALL
。