我有两个相关的分支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可以做到吗?