JPA没有生成"on delete set null"FK限制

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可以做到吗?

Rom*_*las 0

您确定使用@OneToOne 吗?在我看来,您宁愿使用@ManyToOne(因为状态可能会受到多个警报的影响):

@Entity
public class Alarm {
    ...

    @ManyToOne(cascade=CascadeType.ALL)
    @JoinColumn(name="idStatus", nullable=true)
    private Status status;

    ...
}
Run Code Online (Sandbox Code Playgroud)