hibernate 一对多操作(级联操作)

时间:2021-07-30 19:42:04

一对多级联操作

1.  级联保存

复杂写法

Company company = new Company();
company.setcName("Hello");
company.setcAdress("World");
Staff staff = new Staff();
staff.setsName("hi");
staff.setsAge(0);
company.getSetStaff().add(staff);
staff.setCompany(company);
session.save(company);
session.save(staff);

一般写法

配置Company.hbm.xml,在set标签加入cascade="save-update" 表示级联保存

hibernate 一对多操作(级联操作)

Company company = new Company();
company.setcName("Hello");
company.setcAdress("World");
Staff staff = new Staff();
staff.setsName("hi");
staff.setsAge(0);
company.getSetStaff().add(staff);
session.save(company);

保存前

公司表

hibernate 一对多操作(级联操作)

员工表

hibernate 一对多操作(级联操作)

保存后

公司表

hibernate 一对多操作(级联操作)

员工表

hibernate 一对多操作(级联操作)

公司,员工信息都保存成功,并且外键也对应成立

2.  级联删除

配置Company.hbm.xml,在set标签加入cascade="delete" 表示级联删除。

hibernate 一对多操作(级联操作)

 先获取company对象,在调用session的delete方法删除company.

       Company company = new Company();
company = session.get(Company.class, 1);
session.delete(company);

  

删除前

公司表

hibernate 一对多操作(级联操作)

员工表

hibernate 一对多操作(级联操作)

删除后

公司表

hibernate 一对多操作(级联操作)

员工表

hibernate 一对多操作(级联操作)

即公司信息删除后,与删除的公司有关员工也会被删除。实现了级联删除效果。

当未设置Company映射配置文件时,即未在set标签加入cascade="delete"

删除前

公司表

hibernate 一对多操作(级联操作)

员工表

hibernate 一对多操作(级联操作)

删除后

公司表

hibernate 一对多操作(级联操作)

员工表

hibernate 一对多操作(级联操作)

即与删除公司有关的员工不会被删除而是将对应员工的外键设置为null

3.一对多修改操作

将id为4的员工公司改为id为为5的公司

公司表

hibernate 一对多操作(级联操作)

员工表

hibernate 一对多操作(级联操作)

操作:

        Company company = new Company();
company = session.get(Company.class, 5);
Staff staff = new Staff();
staff = session.get(Staff.class, 4);
company.getSetStaff().add(staff);
staff.setCompany(company);

操作后

hibernate 一对多操作(级联操作)

员工的公司外键改为5,成功。