表:学生,地址 Student.ADDR_ID 列映射到 Address.ID
我的学生课上的注释如下
public class Student {
String name, surname;
int rollNumber;
Teacher classTeacher;
Address address;
@OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name="ADDR_ID")
public Address getAddress() {
return address;
}
:
:
它在创建和更新案例中运行良好。
如果我将 Student 的地址更改为新地址,则它会创建一个新行,但不会删除旧地址的行。如果我将地址设置为 null 仍然不会删除
例如
Student s1 = session.get(Student.class, 24);
Address addr = new Address();
session.save(addr);
s1.setAddress(addr);
session.save(s1);
or
Student s1 = session.get(Student.class, 24);
s1.setAddress(null);
我已经设置了级联所有。需要做哪些额外/不同的事情。Inverse 在这里适用吗?