级联操作:

属性:cascade

值:save-update(级联保存)

delete(级联删除)

all(级联保存+级联删除)

优点:虽然,不用级联操作也能解决问题。但是级联操作可以减少代码量,使得操作变得更加简洁。

一、一对多

以下演示为操作一的一方(班级),同时实现对班级下的学生的增加删除操作,配置文件的修改是在一的一方(班级):

1、级联保存:

(1)不使用级联保存:

一般情况下向一个不存在的班级中添加学生,在设置了班级与学生的一对多、多对一关系后,需要调用save方法对班级和学生进行保存,如果有很多个学生会比较麻烦。

一对多配置:

 <set name="students" table="student" ><!--一对多关系配置-->
<key column="classno" update="false"></key><!--指定了集合表的外键-->
<one-to-many class="Student"></one-to-many>
</set>
public static void testadd1() {
Session session = HibernateUtils.openSession();//获得session
Transaction transaction = session.beginTransaction();//开启事务
Clas clas=new Clas();
clas.setClassname("计科171");
clas.setClassno(4600);
clas.setDepartment("一号楼");
clas.setMonitor("zhai"); Student student=new Student();
student.setSname("翟");
student.setStudentno(2017151411);
student.setPoint(123f);
student.setSex("男");
student.setBirthday("2019-11-11");
student.setPhone("18739496522");
student.setClassno("221221");
student.setEmail("34288334@qq.com"); Student student1=new Student();
student1.setSname("翟hb");
student1.setStudentno(2017151419);
student1.setPoint(666f);
student1.setSex("女");
student1.setBirthday("2019-11-11");
student1.setPhone("18739496522");
student1.setClassno("221221");
student1.setEmail("34288334@qq.com"); clas.getStudents().add(student);//一对多,一个班级下有多个学生
clas.getStudents().add(student1);//获取Set集合对象并向其中添加元素 student.setaClas(clas);//多对一,学生属于哪一个班级
student1.setaClas(clas); session.save(clas);
session.save(student);
session.save(student1);//需要执行save方法对学生和班级进行保存 transaction.commit();//提交事务
session.close();//关闭资源
}

(2)使用级联保存:

配置文件(需要添加cascade属性):

<set name="students" cascade="save-update"><!--一对多关系配置-->
<key column="classno" update="false"></key><!--指定了集合表的外键-->
<one-to-many class="Student"></one-to-many>
</set>
 public static void testadd1() {
Session session = HibernateUtils.openSession();//获得session
Transaction transaction = session.beginTransaction();//开启事务
Clas clas=new Clas();
clas.setClassname("计科171");
clas.setClassno(46);
clas.setDepartment("一号楼");
clas.setMonitor("zhai"); Student student=new Student();
student.setSname("翟");
student.setStudentno(210);
student.setPoint(123f);
student.setSex("男");
student.setBirthday("2019-11-11");
student.setPhone("18739496522");
student.setEmail("34288334@qq.com"); Student student1=new Student();
student1.setSname("翟hb");
student1.setStudentno(112);
student1.setPoint(666f);
student1.setSex("女");
student1.setBirthday("2019-11-11");
student1.setPhone("18739496522");
student1.setEmail("34288334@qq.com"); clas.getStudents().add(student);//一对多,一个班级下有多个学生
clas.getStudents().add(student1);//获取Set集合对象并向其中添加元素 session.save(clas); transaction.commit();//提交事务
session.close();//关闭资源
}

 在保存的时候只需要保存一的一方,减少了代码量。 

2、级联删除:

(1)普通方法:

配置文件:

 <set name="students"><!--一对多关系配置-->
<key column="classno" update="false"></key><!--指定了集合表的外键-->
<one-to-many class="Student"></one-to-many>
</set>
 public static void testDel() {
Session session = HibernateUtils.openSession();//获得session
Transaction transaction = session.beginTransaction();//开启事务
Clas clas=session.get(Clas.class,90865);//获得要删除的学生属于那一个班级
Student student1=session.get(Student.class,937221539);//获得要删除的学生
Student student2=session.get(Student.class,937221540);//获得要删除的学生
clas.getStudents().remove(student1);
clas.getStudents().remove(student2);
student1.setaClas(null);
student2.setaClas(null);
session.remove(clas);
transaction.commit();//提交事务
session.close();//关闭资源
}  

对一个班级和班级下的两名学生进行删除操作,需要先对学生进行删除,然后删除学生所在的班级,如果学生数量比较多,那么操作起来是相当麻烦的。

(2)级联删除:

先对配置文件添加cascade属性:

 <set name="students" cascade="delete"><!--一对多关系配置-->
<key column="classno" update="false"></key><!--指定了集合表的外键-->
<one-to-many class="Student"></one-to-many>
</set>
 public static void testDel() {
Session session = HibernateUtils.openSession();//获得session
Transaction transaction = session.beginTransaction();//开启事务
Clas clas=session.get(Clas.class,);//获得要删除的学生属于那一个班级
session.delete(clas);
transaction.commit();//提交事务
session.close();//关闭资源
}

在进行删除操作的时候,只需要删除一的一方(班级),多的一方(学生),也会被删除。即,在对某一个班级进行删除的时候,班级下的所有学生一起也被删除了,减少了代码量,尤其是在学生数量较多的情况下优点更为明显。

二、多对一:

1、级联保存:

(1)在多的一方(学生)对配置文件增加cascade属性:

<many-to-one cascade="save-update" name="aClas" column="classno" class="Clas"></many-to-one>

(2)在增加学生的同时,会把学生所在的班级一同进行添加:

public static void testadd1() {
Session session = HibernateUtils.openSession();//获得session
Transaction transaction = session.beginTransaction();//开启事务
Clas clas=new Clas();
clas.setClassname("计科171");
clas.setClassno(46);
clas.setDepartment("一号楼");
clas.setMonitor("zhai"); Student student=new Student();
student.setSname("翟");
student.setStudentno(210);
student.setPoint(123f);
student.setSex("男");
student.setBirthday("2019-11-11");
student.setPhone("18739496522");
student.setEmail("34288334@qq.com"); clas.getStudents().add(student);//获取Set集合对象并向其中添加元素
student.setaClas(clas); session.save(student); transaction.commit();//提交事务
session.close();//关闭资源
}

  

Hibernate的级联保存、级联删除的更多相关文章

  1. hibernate 一对多 级联 保存修改 删除

    一对多,一端设置: <set name="TWorkorderHistories" inverse="true" cascade="all&qu ...

  2. 【JPA 级联保存/级联删除】@OneToMany (双向) 一对多【转】

    [http://blog.sina.com.cn/s/blog_625d79410101dbdd.html]   看过前两篇帮助文档 [JPA] @OneToOne 单向 和 [JPA]@OneToO ...

  3. (原创)Hibernate 使用过程中(尤其是多对多关联中的级联保存和级联删除)的注意事项(基于项目的总结)

    一.先上知识点: 1.hibernate多对多关联关系中最重要的参数是(基于配置文件xxx.hbm.xml文件形式): 1):inverse属性,如果设置inverse=“true”就代表让对方参与维 ...

  4. Hibernate中表与表之间的关联多对多,级联保存,级联删除

    第一步:创建两个实体类:用户和角色实体类,多对多关系,并让两个实体类之间互相关联: 用户实体类: package com.yinfu.entity; import java.util.HashSet; ...

  5. Hibernate中表与表之间的关联一对多,级联保存和级联删除

    1:Hibernate的一对多操作(重点) 一对多映射配置 第一步:创建两个实体类:客户和联系人(例)以客户为一,联系人为多: package com.yinfu.entity; public cla ...

  6. 再谈Hibernate级联删除——JPA下的Hibernate实现一对多级联删除CascadeType.DELETE_ORPHAN

    声明: 1.本文系原创,非抄袭或转载过来的. 2.本文论点都亲手做过实验论证. 3.本文所讲的Hibernate配置都基于注解的方式,hbm语法未提供. 非常多人对持久层概念搞不清JPA.Hibern ...

  7. Hibernate入门(八)级联保存或更新(含问题在末尾,求大佬指点..)

    级联保存或更新CASCADE 级联保存或更新: 作用就是:保存一方的数据的时候,会把关联的对象也同时保存. 级联保存或更新的配置: 属性名:cascade 属性值: 1.none:所有情况下均不进行关 ...

  8. Java三大框架之——Hibernate关联映射与级联操作

    什么是Hibernate中的关联映射? 简单来说Hibernate是ORM映射的持久层框架,全称是(Object Relational Mapping),即对象关系映射. 它将数据库中的表映射成对应的 ...

  9. 六 Hibernate多表操作&级联&外键维护

    Hibernate的一对多关联映射 Hibernate的多对多关联映射 数据库表与表之间的关系:一对多,多对多,一对一 一对多:一个部门对应多个员工,一个员工只能属于一个部门.一个客户对应多个联系人, ...

随机推荐

  1. Java学习:Set接口与HashSet集合存储数据的结构(哈希表)

    Set接口 java.util.Set接口 extends Collection接口 Set接口的特点: 不允许存储重复的元素 没有索引,没有带索引的方法,也不能使用普通的for循环遍历 java.u ...

  2. EF之DataBase添加新表

    由于需要新增的XML数据较多,可以另起项目,将新增的XML数据复制到原来的EF

  3. asp.net core 系列之允许跨域访问2之测试跨域(Enable Cross-Origin Requests:CORS)

    这一节主要讲如何测试跨域问题 你可以直接在官网下载示例代码,也可以自己写,我这里直接使用官网样例进行演示 样例代码下载: Cors 一.提供服务方,这里使用的是API 1.创建一个API项目.或者直接 ...

  4. 用C#搭建WebSocket

    WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议. WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据.在 W ...

  5. dapper.common新增概念object to sql

    Dapper.Common About author Email:@qq.com QQ: QQGroup: Config DbContextFactory.AddDataSource(new Data ...

  6. 二.HTML

    1.HTML 1. <head></head>标签 <!DOCTYPE html> <!--统一规范--> <!----> <html ...

  7. [Cocos Creator]安卓上微信小游戏加载到100%就进不去了

    最近用Cocos Creator 开发微信小游戏,构建发布到微信上,用安卓手机预览打开后加载到100%就不动了,开始以为微信开发工具版本的问题,后来用苹果的手机测试了一下,发现也有同样的问题. 仔细分 ...

  8. Java自学-日期 Date

    Java的日期类Date Date类 注意:是java.util.Date; 而非 java.sql.Date,此类是给数据库访问的时候使用的 示例 1 : 时间原点概念 所有的数据类型,无论是整数, ...

  9. Ext.bind函数说明

    bind( fn, [scope], [args], [appendArgs] ) : FunctionCreate a new function from the provided fn, chan ...

  10. MySql操作命令创建学生管理系统

    1.创建学生管理系统数据库xscj create detabase 数据库名: 2.打开数据库 use 数据库名: //创建数据库之后,该数据库不会自动成为当前数据库需要用use来指定 3.创建表名 ...