Hibernate第五篇【inverse、cascade属性详解】
前言
上一篇博文已经讲解了一对多和多对一之间的关系了,一对多和多对一存在着关联关系(外键与主键的关系)。本博文主要讲解Inverse属性、cascade属性。这两个属性对关联关系都有影响
Inverse属性
Inverse属性:表示控制权是否转移..
- true:控制权已转移【当前一方没有控制权】
- false:控制权没有转移【当前一方有控制权】
Inverse属性,是在维护关联关系的时候起作用的。只能在“一”的一方中使用该属性!Inverse属性的默认值为fasle,也就是当前一方是有控制权的
从一下的几个方面看看Inverse在维护关联关系时是否起作用:
- 保存数据
- 获取数据
- 解除关联关系
- 删除数据对关联关系的影响
保存数据
将inverse属性设置为ture,使dept没有控制权
<!--维护关系的是Set集合,对应employee表-->
<set cascade="save-update" name="set" table="employee" inverse="true">
执行保存数据操作时,发现Hibernate只执行了三条SQL语句。employee表的外键并没有数据
结论:如果设置控制反转,即inverse=true, 然后通过部门方维护关联关系。在保存部门的时候,同时保存员工, 数据会保存,但关联关系不会维护。即外键字段为NULL
查询数据
设置inverse属性为true,那么部门一方是没有控制权的。
<set cascade="save-update" name="set" table="employee" inverse="true">
我们在查看数据的时候,发现inverse属性对查询数据是没有影响的
//查询出Dept对象
Dept de = (Dept) session.get(Dept.class, 1);
System.out.println(dept.getDeptName());
System.out.println("-----------");
//用到的时候再查询数据库,Hibernate的懒加载【后面会讲解】
System.out.println(de.getSet());
解除关联关系
部门和员工是存在外键的联系的,我们接下来看看inverse属性对于解除关联关系有没有影响
- 当部门一方有权限时,即inverse属性为false
//查找部门id为1的信息
Dept dept1 = (Dept) session.get(Dept.class, 1);
//清除关联信息
dept1.getSet().clear();
可以解除关联关系,employee的外键字段被设置为NULL了
- 当部门一方没有权限时,即inverse属性为true
//查找部门id为2的信息
Dept dept1 = (Dept) session.get(Dept.class, 2);
//清除关联信息
dept1.getSet().clear();
不能解除关联关系
删除数据对关联关系的影响
- 当部门一方有权限时,即inverse属性为false
//查找部门id为2的信息
Dept dept1 = (Dept) session.get(Dept.class, 2);
//删除部门2
session.delete(dept1);
当有控制权的时候可以删除数据,先把外键设置为NULL,再删除数据!
- 当部门一方没有权限时,即inverse属性为true
//查找部门id为1的信息
Dept dept1 = (Dept) session.get(Dept.class, 1);
//删除部门1
session.delete(dept1);
直接抛出异常,说该部门拥有外键,不能删除数据!
cascade属性
cascade表示级联的意思,简单来说就是操作某一属性时,对其他关联字段的影响
casecade属性不像inverse属性只能在“一”的一方设置,它可以在“一”的一方也可以在“多”的一方设置
cascade有这么几个值
- none 不级联操作, 默认值
- save-update 级联保存或更新
- delete 级联删除
- save-update,delete 级联保存、更新、删除
- all 同上。级联保存、更新、删除
级联保存
级联保存有什么用呢???我们来看个例子:
- 如果在保存对象的时候,没有把相关的对象也一并保存进数据库,会出现错误。
- 因为它会发现dept是有外键的,而外键又是一个对象来保存着,这个对象在数据库表中并没有存在,因此会抛出异常
//创建对象
Dept dept = new Dept();
dept.setDeptName("开发部");
Employee zs = new Employee();
zs.setEmpName("张珊");
zs.setSalary(1111);
Employee ls = new Employee();
ls.setEmpName("李四");
ls.setSalary(2222);
//维护关系
dept.getSet().add(zs);
dept.getSet().add(ls);
//保存dept对象
session.save(dept);
如果我们在dept中设置了级联保存,那么Hibernate就会知道:保存dept的数据时,发现dept了外键,也把dept外键的对象保存在数据库之中
<set name="set" table="employee" cascade="save-update" >
级联删除
级联删除,这个对于我们来说风险太大了,如果删除了某些数据,会把另外有关联的数据也删除…在实际中我们一般不使用!
- 在没有设置级联删除的时候,我们试试删除dept
//删除部门为3的记录
Dept dept1 = (Dept) session.get(dept.getClass(), 3);
session.delete(dept1);
它会先把3的外键对应的记录删除,再删除部门的数据
- 在设置级联删除的时候,我们试试删除dept
<set name="set" table="employee" cascade="save-update,delete" >
- 级联删除数据
//删除部门为4的记录
Dept dept1 = (Dept) session.get(dept.getClass(), 4);
session.delete(dept1);
我们发现数据相关联的数据都没有了
cascade和inverse同时使用
上面我们已经把cascade和inverse都介绍一遍了,那么cascade和inverse同时使用会怎么样呢???我们来测试一下
- 设置dept没有控制权,但设置级联保存、删除
<set name="set" table="employee" cascade="save-update,delete" inverse="true" >
- 添加一个dept对象
//添加一个dept对象
session.save(dept);
如果我们单单设置了inverse属性为true,那么数据库中肯定是不能维护关联关系的【这里我们已经测试了】
但是呢,现在也设置了级联保存,级联保存是可以让该对象相关的关联关系一并保存在数据库中的。
我们来看看结果:
从结果我们可以看出:inverse和cascade是相互独立的。cascade是不能影响着inverse的!
总结
上面的测试都是通过几个方面的,看起来有点多,因此我们总结一下
inverse属性
inverse属性只能在“一”的一方中设置。inverse=false表示有控制权,inverse=ture表示没有控制权
- 在保存关联信息时
- 有控制权—>可以保存相对应的关联数据
- 没有控制权—>数据会保存,但是关联关系没有维护,也就是外键列为NULL
- 在查询数据时
- 有无控制权对查询数据没有任何影响
- 在解除关联关系时
- 有控制权—>可以解除关联关系
- 没有控制权—>不能解除关联关系,不会生成update语句,也不会报错
- 在删除数据时对关联关系的影响
- 有控制权—>将外键的值设置为NULL,随后删除数据
- 没有控制权—>如果删除的记录有被外键引用,会报错,违反主外键引用约束,如果删除的记录没有被引用,可以直接删除。
多对多关系的时候也是一样的,只不过多对多的关联关系是在中间表中
cascade属性
cascade有这么几个值:
- none 不级联操作, 默认值
- save-update 级联保存或更新
- delete 级联删除
- save-update,delete 级联保存、更新、删除
- all 同上。级联保存、更新、删除
我们可能使用到的往往是:save-update这个值,因为级联删除的风险太大了!
- 级联保存
- 没有设置级联保存–>如果单单保存一个对象,而对象又存在外键时,那么就会抛出异常
- 设置了级联保存–>那么就可以将对象以及有关联关系的对象一并保存
- 级联删除
- 没有设置级联删除–>在删除数据的时候,会把外键的字段设置为NULL,再删除当前一方的记录
- 设置了级联删除–>把对象有关联关系的记录都删除了
如果cascade和inverse同时设置时:
- cascade和inverse是相互独立的,cascade不能影响着inverse
Hibernate第五篇【inverse、cascade属性详解】的更多相关文章
- 第五篇Django URL name 详解
Django URL name 详解 利用Django开发网站,可以设计出非常优美的url规则,如果url的匹配规则(包含正则表达式)组织得比较好,view的结构就会比较清晰,比较容易维护. Djan ...
- Vue.js 源码分析(五) 基础篇 方法 methods属性详解
methods中定义了Vue实例的方法,官网是这样介绍的: 例如:: <!DOCTYPE html> <html lang="en"> <head&g ...
- Vue.js 源码分析(十三) 基础篇 组件 props属性详解
父组件通过props属性向子组件传递数据,定义组件的时候可以定义一个props属性,值可以是一个字符串数组或一个对象. 例如: <!DOCTYPE html> <html lang= ...
- Vue.js 源码分析(十一) 基础篇 过滤器 filters属性详解
Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化.过滤器可以用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持).过滤器应该被添加在 JavaScrip ...
- OutputCache属性详解(四)— SqlDependency
目录 OutputCache概念学习 OutputCache属性详解(一) OutputCache属性详解(二) OutputCache属性详解(三) OutputCache属性详解(四)— SqlD ...
- 轻松学习Linux之Shell文件和目录属性详解
轻松学习Linux之Shell文件和目录属性详解 轻松学习Linux之理解Sitcky 轻松学习Linux之理解umask 轻松学习Linux之理解SUID&SGUID 本系列多媒体教程已完成 ...
- android:exported 属性详解
属性详解 标签: android 2015-06-11 17:47 27940人阅读 评论(7) 收藏 举报 分类: Android(95) 项目点滴(25) 昨天在用360扫描应用漏洞时,扫描结果, ...
- Android中的windowSoftInputMode属性详解
这篇文章主要介绍了Android中的windowSoftInputMode属性详解,本文对windowSoftInputMode的9个属性做了详细总结,需要的朋友可以参考下 在前面的一篇文章中 ...
- [转]CSS vertical-align属性详解 作者:黄映焜
CSS vertical-align属性详解 posted @ 2014-08-26 17:44 黄映焜 前言:关于vertical-align属性. 实践出真知. 垂直居中. 第二种用法. ...
随机推荐
- 《Java从入门到放弃》入门篇:hibernate查询——HQL
不知不觉又到了hibernate的最后一篇了,只感觉时光飞逝~,岁月如梭~! 转眼之间,我们就···························,好吧,想装个X,结果装不下去了,还是直接开始吧· ...
- Linux之旅-ubuntu下搭建nodejs环境
.NET Core也开源了,并且可移植到Linux下,而ubuntu作为linux发行版的翘楚,极大的方便了初学者的入门,搭建完ASP.NET Core运行环境后,作为半前半后的开发人员,就继续着搭建 ...
- 关于Java String 类型转换时null的问题(转)
关于Java String 类型转换时null的问题 开发中经常遇到从集合类List.Map中取出数据转换为String的问题,这里如果处理不好,经常会遇到空指针异常java.lang.NullPoi ...
- 学习笔记GAN001:生成式对抗网络,只需10步,从零开始到调试
生成式对抗网络(gennerative adversarial network,GAN),目前最火的非监督深度学习.一个生成网络无中生有,一个判别网络推动进化.学技术,不先着急看书看文章.先把Demo ...
- 【windows】常用快捷键
浏览器 ctrl shift del 清除网页缓存 文件系统 win+e 打开文件窗口 win+r 运行命令窗口 win+l 锁定桌面 win+m 最小化窗口 ctrl+shift +n 创建文件夹
- Redis入门 (CentOS7 + Redis-3.2.1)
1. 编译安装1.1 下载redis # cd /tmp/# wget http://download.redis.io/releases/redis-3.2.1.tar.gz# tar zxvf r ...
- Webpack+Vue+ES6 前端组件化开发mobile-multi-page应用实战总结
本文版权归博客园和作者吴双本人共同所有 转载和爬虫请注明原文地址 www.cnblogs.com/tdws 一.写在前面 项目上线有一段时间了,一个基于webpack+vue+ES6的手机端多页面应用 ...
- 【搬运工】之YSlow安装教程
YSlow安装教程(我只是搬运工,推荐好用的地址) 地址: https://devework.com/yslow.html YSlow (解析为 why slow)是雅虎基于网站优化规则推出的工具,帮 ...
- 原创: rsync软件服务利用ansible实现一键化部署
---恢复内容开始--- 首先创建一个脚本文件 /server/tools/peizhi.sh cat /server/tools/peizhi.sh cat >>/etc/rsyncd ...
- 带你走进SAP项目实施过程——立项(1)
到底谁会首先有上ERP的想法,可能是企业老板,也可能是总经理级别等高管.但不管是谁,在确定之前,按道理企业风控部.总经办或者信息部等相关部门都需要对ERP项目做立项申请.毕竟ERP项目涉及企业方方面面 ...