我有两个相关的类 JPA 注释。警报和状态。一个警报可以有一个状态。
我需要的是能够删除一个状态并将空值“传播”到已删除的状态中的警报。
也就是说,我需要将外键定义为“ on delete set null ”。
@Entity
public class Alarm {
@Id
@GeneratedValue(strategy=GenerationType.SEQUENCE, generator="sequence")
@SequenceGenerator(name="sequence", sequenceName="alarm_pk_seq")
private Integer id;
@OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name="idStatus")
private Status status;
// get/set
}
@Entity
public class Status {
@Id
@Column(name="idStatus")
private Integer id;
private String description;
// get/set
}
例子:
前:
STATUS
id description
1 new
2 assigned
3 closed
ALARMS
id status
1 1
2 2
3 2
之后(删除id=2的状态)
STATUS
id description
1 new
3 closed
ALARMS
id status
1 1
2 NULL
3 NULL
我正在使用 Hibernate 和 PostgreSQL,从源代码自动生成数据库。我已经尝试了所有可能的 CascadeType 都没有成功。
代码有什么问题吗?可以用 JPA 做到这一点吗?