我有两个相关的类JPA注释。警报和状态。一个闹钟可以有一个状态。JPA没有生成“on delete set null”FK的限制
我需要的是能够删除一个状态和“传播”空值是在已删除的状态的报警。
也就是说,我需要将外键定义为“删除集合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
我使用休眠和PostgreSQL,自动生成所述数据库源代码。我已经尝试过所有可能的CascadeType,但没有成功。
代码中有什么问题吗? JPA可以做到吗?
谢谢。你是对的,我刚刚将它改为ManyToOne关系,并添加了nullable = true参数,但结果仍然是相同的:( – 2009-01-24 16:03:56