我有两个相关的条款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吗?