zoukankan      html  css  js  c++  java
  • hibernate 一对多操作(级联操作)

    一对多级联操作

    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" 表示级联保存

     

    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);    

    保存前

    公司表

    员工表

    保存后

    公司表

    员工表

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

    2.  级联删除

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

     先获取company对象,在调用sessiondelete方法删除company.

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

      

    删除前

    公司表

    员工表

    删除后

    公司表

    员工表

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

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

    删除前

    公司表

    员工表

    删除后

    公司表

     

    员工表

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

     3.一对多修改操作

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

    公司表

    员工表

    操作:

            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);

    操作后

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

  • 相关阅读:
    【转】Windows7 下安装 JDK 7 时版本冲突问题解决
    【转】Android开发之旅:环境搭建及HelloWorld
    android开发板
    win7重装系统的配置步骤
    caffe 源码阅读
    caffe 源码阅读
    Python 图像处理: 生成二维高斯分布蒙版
    学习 protobuf(一)—— ubuntu 下 protobuf 2.6.1 的安装
    学习 protobuf(一)—— ubuntu 下 protobuf 2.6.1 的安装
    CMake 添加头文件目录,链接动态、静态库(添加子文件夹)
  • 原文地址:https://www.cnblogs.com/lolybj/p/6266233.html
Copyright © 2011-2022 走看看