热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Hibernate单项级联操作

/*** 级联操作* 在保存班级的同时级联保存学生* */@Testpublic void testSaveClasses_Cascade_Save_Student(){Session se


<hibernate-mapping><class name&#61;"com.sanmao.utils.Classes"><id name&#61;"cid" length&#61;"5"><generator class&#61;"identity">generator>id><property name&#61;"name" length&#61;"20">property><property name&#61;"description" length&#61;"20">property><set name&#61;"stduents" cascade&#61;"save-update" inverse&#61;"true"><key><column name&#61;"cid">column>key><one-to-many class&#61;"com.sanmao.utils.Student">one-to-many>set>class>
hibernate-mapping>

/*** 级联操作* 在保存班级的同时级联保存学生* */&#64;Testpublic void testSaveClasses_Cascade_Save_Student(){Session session&#61;sessionFactory.getCurrentSession();Transaction transaction&#61;session.beginTransaction();Classes classes&#61;new Classes();classes.setName("JAVA");classes.setDescription("厉害");//建立班级与学生之间的关系Set students&#61;new HashSet<>();Student student1&#61;new Student();student1.setName("三毛1");student1.setDescription("你好");Student student2&#61;new Student();student2.setName("三毛2");student2.setDescription("你好");students.add(student1);students.add(student2);classes.setStduents(students);session.save(classes);transaction.commit();}

显示操作

在代码中调用session.save/update方法进行操作的时候&#xff0c;这种情况为显示操作。

隐式操作

在代码中并没有session.save(student)这样的代码&#xff0c;但是最后却形成了保存student

的sql语句&#xff0c;所以这个操作是在hibernate内部执行的&#xff0c;并不是由程序来执行的。


在保存班级的时候级联更新学生

这里写图片描述

说明&#xff1a;
当事务提交的时候&#xff0c;执行了session.flush&#xff1a;
1、检查session一级缓存中所有的持久化对象
如果该对象在数据库中没有相应的记录&#xff0c;则发出insert语句
如果该对象在数据库有相应的记录(有id值)&#xff0c;则和副本进行对比
如果一样&#xff0c;则什么都不做&#xff0c;如果不一样&#xff0c;则发出update语句
2、如果在Classes.hbm.xml文件中的set元素中有cascade选项&#xff0c;并且值为
“save-update”&#xff0c;这个时候&#xff0c;hibernate内部再次会去检查classes的关联对象
Set:students&#xff0c;在set集合中一个一个查找&#xff0c;如果该对象是临时状态
的对象&#xff0c;则发出insert语句&#xff0c;如果是持久化状态的对象&#xff0c;则会对照副本
来判断是否发出update语句


推荐阅读
author-avatar
璋houge
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有