最近学习hibernate
,重点研究了hibernate
属性的inverse
与cascade
的联系与区别。如下,是本人的心得。
1、到底在哪用cascade="..."
?
cascade
属性并不是多对多关系一定要用的,有了它只是让我们在插入或删除对像时更方便一些,只要在cascade
的源头上插入或是删除,所有 cascade
的关系就会被自己动的插入或是删除。便是为了能正确的cascade
,unsaved-value
是个很重要的属性。Hibernate
通 过这个属性来判断一个对象应该save
还是update
,如果这个对象的id
是unsaved-value
的话,那说明这个对象不是 persistence object
要save
(insert)
;如果id
是非unsaved-value
的话,那说明这个对象是persistence object
(数据库中已存在),只要update
就行了。saveOrUpdate
方法用的也是这个机制。
2、到底在哪用inverse="ture"?
“set
的inverse
属性决定是否把对set
的改动反映到数据库中去。inverse=false————
反映;inverse=true————
不反映”inverse
属性默认为false
inverse
属性默认是false
的,就是说关系的两端都来维护关系。这个意思就是说,如有一个Student, Teacher
和TeacherStudent
表,Student
和Teacher
是多对多对多关系,这个关系由TeacherStudent
这个表来表 现。那么什么时候插入或删除TeacherStudent
表中的记录来维护关系呢?在用hibernate
时,我们不会显示的对 TeacherStudent
表做操作。对TeacherStudent
的操作是hibernate
帮我们做的。hibernate
就是看hbm
文件中指 定的是"
谁"
维护关系,那个在插入或删除"
谁"
时,就会处发对关系表的操作。前提是"
谁"
这个对象已经知道这个关系了,就是说关系另一头的对象已经set
或是add
到"
谁"
这个对象里来了。前面说过inverse
默认是false
,就是关系的两端都维护关系,对其中任一个操作都会处发对表系表的操作。当在 关系的一头,如Student
中的bag
或set
中用了inverse
="true"
时,那就代表关系是由另一关维护的(Teacher
)。就是说当这插 入Student
时,不会操作TeacherStudent
表,即使Student
已经知道了关系。只有当Teacher
插入或删除时才会处发对关系表的 操作。所以,当关系的两头都用inverse="true"
是不对的,就会导致任何操作都不处发对关系表的操作。当两端都是inverse= "false"
或是default
值是,在代码对关系显示的维护也是不对的,会导致在关系表中插入两次关系。
在一对多关系中inverse
就更有意义了。在多对多中,在哪端inverse="true"
效果差不多(在效率上)。但是在一对多中,如果要一方维护关 系,就会使在插入或是删除"
一"
方时去update"
多"
方的每一个与这个"
一"
的对象有关系的对象。而如果让"
多"
方面维护关系时就不会有update
操作,因为关系就是在多方的对象中的,直指插入或是删除多方对象就行了。当然这时也要遍历"
多"
方的每一个对象显示的操作修关系的变化体现到DB
中。不管 怎样说,还是让"
多"
方维护关系更直观一些。
(1
)对one-to-many
而言,改变set
,会让hibernate
执行一系列的update
语句, 不会delete/insert
数据
(2
)对many-to-many
而言,改变set,
只修改关系表的数据,不会影响many-to-many
的另一方。
(3
)虽然one-to-many
和many-to-many
的数据库操作不一样,但目的都是一个:维护数据的一致性。
3、cascade
和inverse
有什么区别?
可以这样理解,cascade
定义的是关系两端对象到对象的级联关系;而inverse
定义的是关系和对象的级联关系。
inverse
只对set+one-to-many(
或many-to-many)
有效,对many-to-one, one-to-one
无效。cascade
对关系标记都有效。
inverse
对集合对象整体起作用,cascade
对集合对象中的一个一个元素起作用,如果集合为空,那么cascade
不会引发关联操作。
比如将集合对象置为null
, school.setStudentSet(null)
inverse
导致hibernate
执行:udpate STUDENT set SCHOOL_ID=null where SCHOOL_ID=?
cascade
则不会执行对STUDENT
表的关联更新, 因为集合中没有元素。
再比新增一个school, session.save(school)
inverse
导致hibernate
执行:
for(
对(school
的每一个student ){
udpate STUDENT set SCHOOL_ID=? where STUDENT_ID=? //
将学生的school_id
改为新的school
的id
}
cascade
导致hibernate
执行:
for(
对school
的每一个student ){
session.save(aStudent); //
对学生执行save
操作
}
extends:
如果改变集合中的部分元素(比如新增一个元素),
inverse: hibernate
先判断哪些元素改变了,对改变的元素执行相应的sql
cascade:
它总是对集合中的每个元素执行关联操作。
(在关联操作中,hibernate
会判断操作的对象是否改变)
两个起作用的时机不同:
cascade
:在对主控方操作时,级联发生。
inverse:
在flush
时(commit
会自动执行flush)
,对session
中的所有set
,hibernate
判断每个set
是否有变化,
对有变化的set
执行相应的sql
,执行之前,会有个判断:if( inverse == true ) return;
可以看出cascade
在先,inverse
在后。
inverse
对set + one-to-many
和 set + many-to-many
起的作用不同。hibernate
生成的sql
不同。
对one-to-many
,hibernate
对many
方的数据库表执行update
语句。
对many-to-many, hibernate
对关系表执行insert/update/delte
语句,注意不是对many
方的数据库表而是关系表。
cascase
对set
都是一致的,不管one-to-many
还是many-to-many
。都简单地把操作传递到set
中的每个元素。所以它总是更新many
方的数据库表。
4
、cascade
和inverse
有什么相同?
这两个属性本身互不影响,但起的作用有些类似,都能引发对关系表的更新。
5
、 建议:只对set + many-to-many
设置inverse=false
,其他的标记不考虑inverse
属性,都设为inverse=true
。对cascade
,一 般对many-to-one
,many-to-many
,constrained=true
的one-to-one
不设置级联删除。
分享到:
相关推荐
Hibernate中cascade与inverse属性详解
在 Hibernate 框架中,`cascade` 和 `inverse` 是两个重要的概念,它们主要用于管理对象之间的持久化关系,特别是涉及到一对一(one-to-one)、一对多(one-to-many)和多对多(many-to-many)关系时。这两个属性都...
### Hibernate Inverse 和 Cascade 的详细讲解 #### 一、引言 在ORM(Object-Relational Mapping)领域,Hibernate作为一款流行的Java持久层框架,它提供了丰富的API和配置选项来帮助开发者实现对象与数据库表之间...
在Java的持久化框架Hibernate中,级联操作(Cascade)和反转(Inverse)是两个重要的概念,它们主要用于管理对象关系模型中的关联关系。在一对多的关系中,这些特性可以帮助简化数据操作,提高代码的可读性和维护性...
`inverse`和`cascade`属性是Hibernate集合映射中非常重要的概念,它们帮助开发者更灵活地控制实体之间的关系以及操作的级联行为。合理地使用这两个属性,不仅可以简化代码,还能提高程序的性能和健壮性。然而,不当...
在探讨Hibernate框架中的级联操作(cascade)与控制权反转(inverse)之前,我们需要先对Hibernate有一个基本的理解。Hibernate是一个开放源代码的对象关系映射(ORM)框架,它为Java应用提供了一种将对象模型映射到...
Hibernate中Inverse和Cascade的区别.html
在使用Hibernate时,正确选择和配置cascade选项对于高效地管理和维护实体之间的关系至关重要。通过了解不同选项的特点和应用场景,开发人员可以更加灵活地应对各种业务需求,同时也能够有效地避免潜在的数据一致性...
总之,理解并熟练运用Hibernate的关联映射、cascade和inverse是提升Java持久化编程能力的关键步骤。它们可以帮助我们更高效地管理对象与数据库之间的关系,同时降低开发复杂度。通过实践和研究给出的示例,相信你...
如果我们在ORM工具如Hibernate中定义这种关系,可以设置其中一个关联为“inverse”,表示这个关联的维护责任不在该端。换句话说,更新或删除部门时,相关的员工记录不会被自动更新或删除,反之亦然。这样可以避免...
本文将深入探讨Hibernate中的一对多关系,并重点解析`inverse`属性的作用及其应用。 一对多关系是数据库设计中常见的关联类型,例如一个用户可以拥有多个订单,一个班级可以包含多个学生等。在Hibernate中,通过...
在软件网络技术领域,尤其是在使用Hibernate这种对象关系映射(ORM)框架时,理解和正确使用`cascade`和`inverse`属性至关重要。这两个属性主要用于管理对象之间的关联关系,特别是如何在数据库中维护这些关系。 ...
**标题:“Hibernate关系映射”** 在Java世界中,Hibernate是一个强大的对象关系映射(ORM)框架,它允许开发者将数据库操作转化为面向对象的方式,极大地简化了数据持久化的复杂性。"多对一"关系映射是Hibernate...
### Hibernate关系映射详解 #### 一、引言 Hibernate是一种广泛使用的Java持久化框架,它简化了对象关系映射(Object-Relational Mapping,简称ORM)的过程,使得开发人员可以更加专注于业务逻辑的实现而无需过多...
在Hibernate中,`cascade`和`inverse`是两个重要的概念,它们涉及到对象之间的关系管理和数据持久化。 **1. Hibernate Cascade** `cascade`属性主要用于控制对象间的级联操作。当在主对象上执行保存、更新、删除等...
描述提到“使用cascade和inverse优化区和街道关联关系”,这意味着我们将深入理解Hibernate的cascade和inverse属性,以及它们在双向一对多关联关系中的应用。 Hibernate是Java领域中广泛使用的对象关系映射(ORM)...
hibernate中一对一,一对多,多对多关系的配置,延迟加载,cascade,inverse hibernate查询方式概述,HQL查询,QBC查询,分页,结果集封装方式 ,高级查询 查询的优化,一级缓存,二级缓存,批量查询,注解方式