【学习笔记】Hibernate关联映射(Y2-1-6)
Hibernate关联映射
关联映射就是将关联关系映射到数据库里,在对象模型中就是一个或多个引用。
1.单向多对一关联
准备数据库
部门表和员工表
其中部门表有两列 部门编号和名称
员工表有三列 员工ID 名称 和对应的部门id
部门和员工是一个1:N的关系(一个部门有多个员工 一个员工属于一个部门)
Hibernate 小配置文件
- <class name="Emp" table="EMP">
- <id name="empId" type="java.lang.Integer">
- <!--主键生成策略-->
- <generator class="native"/>
- </id>
- <property name="empName" type="string"/>
- <!--置入一个Dept对象: 多对一-->
- <many-to-one name="dept" class="Dept" column="deptNo"></many-to-one>
- </class>
在员工EMP的小配置文件中加入many-to-one标签
name属性是EMP实体类中的存放部门的集合的名称
实体类代码如下
然后就配置完了((
书写测试类
- Session session;
- Transaction tx;
- @Before
- public void myBefore(){
- session=HibernateUtil.currentSession();
- tx=session.beginTransaction();
- }
- @After
- public void myAfter(){
- tx.commit();
- HibernateUtil.closeSession();
- }
- //修改编号为22的员工所属的部门
- @Test
- public void updateEmpToOtherDept(){
- Emp emp = session.load(Emp.class, 22);
- Dept dept=session.load(Dept.class,28);//上下文跟踪到
- emp.setDept(dept);
- session.saveOrUpdate(emp);
- }
- //2.按照指定的部门对象28,查询相关的Emp对象
- @Test
- public void selectEmpsByDeptId(){
- String hql="from Emp where dept.deptNo=28";
- Query query = session.createQuery(hql);
- List<Emp> list = query.list();
- for (Emp emp:list) {
- System.out.println(emp.getEmpName());
- }
- }
- //输出指定的emps集合中的所有emp对象及其所关联的部门对象的信息
- @Test
- public void selectEmpInfo(){
- String hql="from Emp";
- Query query = session.createQuery(hql);
- List<Emp> list = query.list();
- for (Emp emp:list) {
- System.out.println(emp.getEmpName()+"\t"+emp.getDept().getDeptName());
- }
- }
2.双向一对多关联
依然是我们的部门表DEPT和员工表EMP
我们就不做截图了
现在实体类中
Dept部门中保存着一个员工的集合
Emp员工中也存放着一个Dept对象 关联着的是对应的部门
部门的实体类如下
Hibernate小配置文件
- <class name="Dept" table="DEPT">
- <id name="deptNo" type="java.lang.Integer">
- <!--主键生成策略-->
- <generator class="native"/>
- </id>
- <property name="deptName" type="string"/>
- <!--一对多配置 一个部门有N个员工-->
- <set name="emps" cascade="save-update" inverse="true">
- <key column="deptNo"></key><!--多的一方的外键-->
- <one-to-many class="Emp"/>
- </set>
- </class>
在关联员工的Set集合时 使用Set标签
name属性对应实体类中的集合名称
key标签是一对多中多的一方的外键 对应的列是部门的编号
one-to-many表示一对多 关联的实体类是Emp员工类
Set标签的其他属性说明
1.cascade属性
当几个对象需要级练操作的时候可以使用该属性
适用场景:当小配置需要反馈对象间关系
2.inverse属性指定了关联关系中的方向
1.inverse设置为false 则为主动方,由主动方负责维护关联关系 ,默认是false
2.inverse设置为true,不负责维护关联关系
//inverse属性建议设置为true
//在建立两个对象的双向关联时,应该同时修改关联两端的对象的相应属性
3.order-by
书写测试类
- @Test
- public void manyToOneDouble(){
- Session session= HibernateUtil.currentSession();
- Transaction tx=session.beginTransaction();
- Dept dept=new Dept();
- dept.setDeptName("17");
- Emp emp=new Emp();
- emp.setEmpName("天命");
- emp.setDept(dept);
- //dept.getEmps().add(emp);
- session.save(dept);
- session.save(emp);
- tx.commit();
- HibernateUtil.closeSession();
- }
延迟加载
延迟加载(lazy load)是当在真正需要数据时,才执行SQL语句进行查询 避免了无谓的开销
<class name="Dept" table="DEPT" lazy="true/false">
(默认lazy为true)
lazy属性只对load()方法有效 (对get无效)
类级(当前类中)
2.关联级别
<set name="emps" lazy="true/false/extra" lazy="true" cascade="save-update" inverse="true">
<key>
<column name="DEPTNO"></column>
</key>
<......>
</set>
lazy="true/false/extra"
true:延迟加载
false:立即加载
extra:扩展(极其懒惰)
【学习笔记】Hibernate关联映射(Y2-1-6)的更多相关文章
- Hibernate学习笔记-Hibernate关系映射
1. 初识Hibernate——关系映射 http://blog.csdn.net/laner0515/article/details/12905711 2. Hibernate 笔记8 关系映射1( ...
- 1.4(Mybatis学习笔记)关联映射
一.一对一 mybatis处理一对一主要通过<resultMap>中的<association>元素来处理. <association>元素主要使用方方式有两种: ...
- MyBatis:学习笔记(3)——关联查询
MyBatis:学习笔记(3)--关联查询 关联查询 理解联结 SQL最强大的功能之一在于我们可以在数据查询的执行中可以使用联结,来将多个表中的数据作为整体进行筛选. 模拟一个简单的在线商品购物系统, ...
- Hibernate关联映射关系
Hibernate关联映射关系 一.双向一对多关联映射关系:当类与类之间建立了关联,就可以方便的从一个对象导航到另一个或另一组与它关联的对象(一对多双向关联和多对一双向关联是完全一样的) 1.1创建实 ...
- Oracle primary,unique,foreign 区别,Hibernate 关联映射
Oracle primary,unique,foreign 区别 转:http://www.cnblogs.com/henw/archive/2012/08/15/2639510.html NOT N ...
- 第六章 Hibernate关联映射
第六章 hibernate关联映射一.本章知识点分为2部分:1.关联关系:单向多对一关联关系,双向一对多关联关系(含一对多关联关系),多对多关联关系2.延迟加载:类级别加载策略,一对多加载策略,多对一 ...
- 第三章Hibernate关联映射
第三章Hibernate关联映射 一.关联关系 类与类之间最普通的关系就是关联关系,而且关联是有方向的. 以部门和员工为列,一个部门下有多个员工,而一个员工只能属于一个部门,从员工到部门就是多对一关联 ...
- (转)MyBatis框架的学习(五)——一对一关联映射和一对多关联映射
http://blog.csdn.net/yerenyuan_pku/article/details/71894172 在实际开发中我们不可能只是对单表进行操作,必然要操作多表,本文就来讲解多表操作中 ...
- (转)Hibernate关联映射——对象的三种关系
http://blog.csdn.net/yerenyuan_pku/article/details/70148618 Hibernate关联映射——对象的三种关系 Hibernate框架基于ORM设 ...
随机推荐
- Mezzanine (Windows10下)安装配置与修改(更新中)
最近自己搭个系统,发现Mezzanine很快,先搞个python 2.7, pip. 然后两个方法: 1. $ pip install mezzanine 2. Git下载,解压 后进入目录,创建项目 ...
- MYSQL DISTINCT Optimization
在很多情况下,Distinct和order by的组合需要建立一个内存临时表. 因为distinct关键字可能利用group by,所以了解下mysql如何处理group by有帮助. distin ...
- 记一些安卓app反编译修改的记录
2017-12-2209:00:40 好几天没有写过博客了,因为马上要期末考试,只能暂且放下我的小玩物,专心复习我的期末考试. 今天突然想设置一个安卓的栏目,记录下自己从高中就爱玩的一些东西,像刷机呀 ...
- HX711初步处理记录
参考文档为极客工坊大神记录 http://www.geek-workshop.com/forum.php?mod=viewthread&tid=2315&highlight=hx711 ...
- glReadPixel 读取数据错误问题
glReadPixel 读取数据错误问题 问题:在Android上使用 glReadPixel 读取当前渲染数据,在若干机型(华为P9以及魅族某魅蓝手机)上读取数据失败,glGetError() 没有 ...
- Runtime.addShutdownHook的用法
原文出处:http://kim-miao.iteye.com/blog/1662550.感谢作者的无私分享. 一.Runtime.addShutdownHook理解 在看别人的代码时,发现其中有这个方 ...
- Linux修改主机名脚本-不重启-支持RedHat、SUSE
需要用脚本修改主机名,涉及RedHat.SUSE系统,并且要求修改立即生效且不重启,下面就是我的脚本. 使用脚本的方法如下: 1 首先创建一个脚本文件,假如命名为ModifyHostname.sh: ...
- Servlet--HttpServletRequest一些不常用的方法
我们在使用Servlet和表单进行交互的时候,不管是传参和接参经常要写一些路径.关于具体的Servlet的传参和接参我后面会有详细的整理,这里先整理一下不怎么常用的到一些HttpServletRequ ...
- SQL 2005/2008 连接SQL 2000报18456错误
在看文章前,你先看看下面这两个问题,考考你对MSSMS工具的掌握情况: 1: SQL 2005/2008 能连接 SQL 2000数据库服务器吗? 2: SQL 2000 能连接SQL 2005/20 ...
- 小白成长系列--HTTP协议(一)
序:小白成长系列是笔者使用最简单易懂的逻辑来解释常见的计算机相关知识,不仅理解,还让你记忆深刻\(^o^)/ 先理解什么是协议? 协议就是双方要做某件事情而制定的规则,而且双方必须要遵从协议所约定的内 ...