Hibernate入门BLOG[十一、Hibernate表关联的级联操作]

本文通过一个部门与员工的案例,详细介绍了Hibernate中级联属性的使用方法。重点在于配置文件中的级联选项,如save-update等,及其如何影响部门与员工之间的关联操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Hibernate操作级联: 我想大家都知道hibernate的级联关系。还是拿我们的dept和emp的案例。 1、 Javabean Dept.java public class Dept { private int id; private String deptname; //一对多的体现 private Set<Employee> emps; } Employee.java public class Employee { private int id; private String empname; //多对一的关系。设置一方为多方的属性 private Dept dept; } 这是一个多对多的关系。1个员工可能属于多个部门。1个部门可以有多个员工。如果我们新增了一个部门那么对应的员工如何做不做级联操作呢,也就是不增加相应的员工。还是我们单独去给他另外一步操作.请看配置文件实例解析: 在这个案例中。我们增加一个部门一个员工。如果我们单独的去save部门信息那么对象里面set的员工会不会增加呢?这个取决于配置文件中的cascade属性。它是一个级联项,可以同时delete、update和insert s = HibernateUtil.getSession(); tx = s.beginTransaction(); Dept dept = new Dept(); Employee emp = new Employee(); dept.setDeptname("bumen1"); emp.setEmpname("emp1"); emp.setDept(dept); s.save(dept); s.save(emp); tx.commit(); 配置文件: <?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="cn.hibernate.model"> <class name="Dept" table="dept"> <id name="id"> <generator class="native"/> </id> <property name="deptname" column="deptname"/> <!--一对多的对象模型关系、跟着发生update或者insert,不用再单独去insertemp对象, cascade级联。--> <set name="emps" cascade="save-update"> <!-- 和多方的配置文件也就是emp的配置文件中设置的对应dept_id是一样的 --> <key column="dept_id"></key> <!-- one-to-many指定多方是哪个表 --> <one-to-many class="Employee"/> </set> </class> </hibernate-mapping>

Cascade属性解析:



级联操作一个insert部门的输出:

Hibernate: insert into dept(deptname) values (?)

Hibernate: insert into employee(empname, dept_id) values (?, ?)

Hibernate: update employee setdept_id=? where id=?


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值