JPA 不生成“删除时设置为空”FK 限制

2023-11-23

我有两个相关的 JPA 注释类。警报和状态。一个警报可以有一个状态。

我需要的是能够删除一个状态并将空值“传播”到已删除的该状态中的警报。

也就是说,我需要将外键定义为“删除时设置为空".

@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
}

Example:

Before:

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来做吗?


只需使用 Hibernate 注释添加即可:

@OnDelete(action=OnDeleteAction.CASCADE)

生成外键为:“ON UPDATE NO ACTION ON DELETE CASCADE;”

但没有action=OnDeleteAction.SET_NULL

此外,如果可能的话,我不喜欢将我的代码与 Hibernate 绑定(但如果它有效的话我可以忍受)。

This thread讨论它。我不敢相信 JPA(或 Hibernate 扩展)中没有一种简单的方法来生成外键。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

JPA 不生成“删除时设置为空”FK 限制 的相关文章

随机推荐