Hibernate中的一对多与多对一映射
1.需求
一个部门有多个员工; 【一对多】
多个员工,属于一个部门 【多对一】
2.实体Bean设计
Dept:
public class Dept {
private int depId;
private String depName;
private Set<Employee> emps = new HashSet<Employee>();
set...
get...
}
Employee:
public class Employee {
private int empId;
private String empName;
private double salary;
private Dept dept;
set...
get...
}
3.配置映射文件
Dept.hbm.xml
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.juaner.hibernate.department">
<class name="Dept" table="t_dept">
<!--主键-->
<id name="depId">
<generator class="native"/>
</id>
<property name="depName" column="deptName" type="string"/>
<!--一对多关联映射的配置-->
<set name="emps" table="t_employee" >
<!--外键字段-->
<key column="dept_id"></key>
<!--一对多关系-->
<one-to-many class="Employee"/>
</set>
</class> </hibernate-mapping>
Employee.hbm.xml
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.juaner.hibernate.department">
<class name="Employee" table="t_employee">
<!--主键-->
<id name="empId" column="empId">
<generator class="native"/>
</id>
<property name="empName" column="empName" type="string"/>
<property name="salary" column="salary"/>
<!--多对一映射-->
<many-to-one name="dept" column="dept_id" class="Dept"></many-to-one>
</class> </hibernate-mapping>
4.保存数据
- 使用“一”的一方来设置关联
@Test
public void test1(){
Session session = sf.openSession();
session.beginTransaction(); //部门对象
Dept dept = new Dept();
dept.setDepName("开发部");
//员工对象
Employee employee = new Employee();
employee.setEmpName("张三");
employee.setSalary(1000);
Employee employee2 = new Employee();
employee2.setEmpName("李四");
employee2.setSalary(2000); dept.getEmps().add(employee);
dept.getEmps().add(employee2); session.save(dept);
session.save(employee);
session.save(employee2); session.getTransaction().commit();
session.close();
}
此时会执行5条sql语句,其中最后两条update语句用来设置关联:
Hibernate: insert into t_dept (deptName) values (?)
Hibernate: insert into t_employee (empName, salary, dept_id) values (?, ?, ?)
Hibernate: insert into t_employee (empName, salary, dept_id) values (?, ?, ?)
Hibernate: update t_employee set dept_id=? where empId=?
Hibernate: update t_employee set dept_id=? where empId=?
- 使用“多”的一方来设置关联
@Test
public void test2(){
Session session = sf.openSession();
session.beginTransaction(); //部门对象
Dept dept = new Dept();
dept.setDepName("人事部");
//员工对象
Employee employee = new Employee();
employee.setEmpName("张三");
employee.setSalary(1000);
Employee employee2 = new Employee();
employee2.setEmpName("李四");
employee2.setSalary(2000); employee.setDept(dept);
employee2.setDept(dept);
//先保存一的一方,再保存多的一方,关系会自动维护,减少不必要的语句
session.save(dept);
session.save(employee);
session.save(employee2); session.getTransaction().commit();
session.close(); }
此时只执行三条sql语句:
Hibernate: insert into t_dept (deptName) values (?)
Hibernate: insert into t_employee (empName, salary, dept_id) values (?, ?, ?)
Hibernate: insert into t_employee (empName, salary, dept_id) values (?, ?, ?)
5.结果
t_dept表:

t_employee表:

6.inverse属性
inverse属性用来设置是否控制反转。在一对多的映射中,只能在“一”的一方配置,默认值为false,即“一”的一方掌握控制权。inverse的值对数据的影响如下:
- 保存数据 有影响
如果设置控制反转,即inverse=true, 然后通过部门方维护关联关系。在保存部门的时候,同时保存员工, 数据会保存,但关联关系不会维护。即外键字段为NULL
- 获取数据 无影响
- 解除关联关系 有影响
inverse=false, 可以解除关联
inverse=true, 当前方没有控制权,不能解除关联关系(不会生成update语句,也不会报错)
- 删除数据对关联关系 有影响
inverse=false, 有控制权, 可以删除。先清空外键引用,再删除数据
inverse=true, 没有控制权: 如果删除的记录有被外键引用,会报错,违反主外键引用约束! 如果删除的记录没有被引用,可以直接删除
7.cascade属性
cascade属性用来设置级联方式,它有4个值:
none 不级联操作, 默认值
save-update 级联保存或更新
delete 级联删除
all 级联保存、更新、删除
Hibernate中的一对多与多对一映射的更多相关文章
- Hibernate之关联映射(一对多和多对一映射,多对多映射)
~~~接着之前的Hibernate框架接着学习(上篇面试过后发现真的需要学习以下框架了,不然又被忽悠让去培训.)~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射: 1.1: ...
- Hibernate之关联关系映射(一对多和多对一映射,多对多映射)
~~~接着之前的Hibernate框架接着学习(上篇面试过后发现真的需要学习一下框架了,不然又被忽悠让去培训.)~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射: 1.1: ...
- java web(六):mybatis之一对一、一对多、多对多映射
前言: 百度百科: MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可 ...
- Hibernate 中一对多和多对多映射
1. 一对多映射 1.1 JavaWeb 一对多建表原则 多方表的外键指向一方表的主键; 1.2 编写一对多的 JavaBean // 客户(一方)和联系人(多方) // 客户(一方) JavaBea ...
- Hibernate中的一对多关系详解(2)
一对多的关系:例如,部门对员工,一个部门可以有多个员工 多对一的关系:例如,员工对部门,多个员工属于一个部门,并且每个员工只能属于一个部门 那么一对多.多对一在数据库中的是怎样表示的呢?好多话都不说了 ...
- Hibernate在关于一对多,多对一双向关联映射
[Hibernate]之关于一对多,多对一双向关联映射 因为一对多.和多对一的双向关联映射基本上一样,所以这里就一起写下来! Annotations配置 @Entity @Table(name=&qu ...
- Hibernate关联关系配置(一对多,一对一,多对多)
一对多 创建两个类 Manager(一这一端) Worker(多这一端) 即一个经理下有多个员工 package com.hibernate.n21; import java.util.HashS ...
- Hibernate的集合一对多与多对一
需求: 部门与员工 一个部门有多个员工; [一对多] 多个员工,属于一个部门 [多对一] 1.javaBean ——Dept.java package com.gqx.oneto ...
- Hibernate一对一、一对多、多对多注解映射配置
一对一: 一对多: 多对多:
随机推荐
- The new day of my blog
今天开始了我的博客建造之旅,作为一个ACMer(虽说是弱校的),我也想象其他人一样把自己的题解和心得记录下来,一来可以和大家分享一下,二来也可以留给将来的自己作回顾,希望众大神能够给以指导指导,让我这 ...
- D3.js 交互式操作
与图表的交互,指在图形元素上设置一个或多个监听器,当事件发生时,做出相应的反应. 一.什么是交互 交互,指的是用户输入了某种指令,程序接受到指令之后必须做出某种响应.对可视化图表来说,交互能使图表更加 ...
- Sublime3基础使用技巧
1.安装SideBarEnhancements插件 ctrl+shift+p —> Install Package —> 找到SideBarEnhancements 2.安装CSS调色器: ...
- 【论文阅读记录】Real-Time Correlative Scan Matching
这篇文章是谷歌的Cartograph中实现real_time_correlative_scan_matcher的论文 Real-Time Correlative Scan MatchingEdwin ...
- 谈谈JPA-02-HelloWorld
使用JPA持久化对象的步骤 创建 persistence.xml, 在这个文件中配置持久化单元 需要指定跟哪个数据库进行交互; 需要指定 JPA 使用哪个持久化的框架以及配置该框架的基本属性 创建实体 ...
- p标签中的span标签文字垂直居中对齐
<p>轻舞飞扬<span>第一次亲密接触</span></p> p标签的font-size:30px; span标签的font-size:24px; 让 ...
- cf------(round)#1 C. Ancient Berland Circus(几何)
C. Ancient Berland Circus time limit per test 2 seconds memory limit per test 64 megabytes input sta ...
- Java 集合系列 05 Vector详细介绍(源码解析)和使用示例
java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...
- jquery ajax请求方式与提示用户正在处理请稍等,等待数据返回时loading的显示
1.jquery ajax请求方式与提示用户正在处理请稍等 为了提高用户体验度,我们通常会给出 “正在处理,请稍等!”诸如此类的提示.我们可通过设置$.ajax()下的参数beforeSend()来实 ...
- enum使用总结
enum的一般使用方法是它会占用最大的成员长度 然后我忘记的是enum还可以这样使用 enum ExctState { START, SUCCEED, FAILURE=6, REJECT, }; 这样 ...