Gui*_*ido 10 java orm hibernate jpa foreign-keys
我有两个相关的分支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
}
Run Code Online (Sandbox Code Playgroud)
例:
之前:
STATUS
id description
1 new
2 assigned
3 closed
ALARMS
id status
1 1
2 2
3 2
Run Code Online (Sandbox Code Playgroud)
之后(删除id = 2的状态)
STATUS
id description
1 new
3 closed
ALARMS
id status
1 1
2 NULL
3 NULL
Run Code Online (Sandbox Code Playgroud)
我正在使用Hibernate和PostgreSQL,从源代码自动生成数据库.我尝试过每一种可能的CascadeType都没有成功.
代码有什么问题吗?用JPA可以做到吗?
您确定使用@OneToOne 吗?在我看来,您宁愿使用@ManyToOne(因为状态可能会受到多个警报的影响):
@Entity
public class Alarm {
...
@ManyToOne(cascade=CascadeType.ALL)
@JoinColumn(name="idStatus", nullable=true)
private Status status;
...
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9455 次 |
| 最近记录: |