- 浏览: 1336292 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (471)
- 原创文章 (4)
- Database (84)
- J2SE (63)
- Web (26)
- Javascript (30)
- Lucene (11)
- os (13)
- 算法 (8)
- Webservice (1)
- Open projects (18)
- Hibernate (18)
- Spring (15)
- Css (2)
- J2ee (2)
- 综合技术 (18)
- 安全管理 (13)
- PatternsInJava (27)
- NIO (5)
- Ibatis (2)
- 书籍收藏 (1)
- quartz (7)
- 并发编程 (15)
- oracle问题 (2)
- ios (60)
- coco2d-iphone (3)
- C++ (6)
- Zookeeper (2)
- golang (4)
- animation (2)
- android (1)
最新评论
-
dandingge123:
【引用】限制UITextField输入长度的方法 -
qja:
...
对List顺序,逆序,随机排列实例代码 -
安静听歌:
现在在搞这个,,,,,哎~头都大了,,,又freemarker ...
通用大型网站页面静态化解决方案(一) -
springdata-jpa:
java quartz定时任务demo教程源代码下载,地址:h ...
Quartz 配置参考 -
马清天:
[b][/b][list][*]引用[u][/u][/list ...
通用大型网站页面静态化解决方案(一)
首先引用另一个blog的说法:
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"?
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中。不管怎样说,还是让"多"方维护关系更直观一些。
3.cascade和inverse 有什么区别?
可以这样理解,cascade定义的是关系两端对象到对象的级联关系;而inverse 定义的是关系和对象的级联关系。在一对多映射中,一的一方要设<set (inverse ="false") casecade="save-update" />,多的一方要设<many-to-one inverse =true (casecade="none") />
Wenic的blog:Wenic的blog:http://www.matrix.org.cn/blog/wenic705
------------------------------------
这个是我做的用例。测试cascade和inverse .分析结果以及具体hibernate sql都在,比较容易看明白。
希望不是很明白的看看,加深印象。
小弟学识浅薄,如果有不对的地方,请指出来,谢谢!~
测试环境:Eclispe,用断点测试。
数据库是SQLServer2000.
Area.hbm.xml
- <?xml version="1.0" encoding="utf-8"?>
- <!DOCTYPE hibernate
- -mapping PUBLIC "-//Hibernate
- /Hibernate
- Mapping DTD 2.0//EN" "http://hibernate
- .sourceforge.net/hibernate
- -mapping-2.0.dtd"; >
- <hibernate
- -mapping>
- <class name="net.villion.model.test.Area" table="r_area">
- <id column="ID" type="long" name = "id" length="10" unsaved-value="null">
- <generator class = "native"/>
- </id>
- <property column="name" name="name" type="string"/>
- <many-to-one name="state" class="net.villion.model.test.State" cascade="all">
- <column name="stateid" index="index_area_state"/>
- </many-to-one>
- </class>
- </hibernate
- -mapping>
State.hbm.xml
- <?xml version="1.0" encoding="utf-8"?>
- <!DOCTYPE hibernate
- -mapping PUBLIC "-//Hibernate
- /Hibernate
- Mapping DTD 2.0//EN" "http://hibernate
- .sourceforge.net/hibernate
- -mapping-2.0.dtd"; >
- <hibernate
- -mapping>
- <class name="net.villion.model.test.State" table="r_state">
- <id column="ID" type="long" name = "id" length="10" unsaved-value="null">
- <generator class = "native"/>
- </id>
- <property column="name" name="name" type="string"/>
- <set name="areas" lazy="true" cascade="all" inverse
- ="false">
- <key column="stateid"/>
- <one-to-many class="net.villion.model.test.Area"/>
- </set>
- </class>
- </hibernate
- -mapping>
我们主要看inverse ,cascade级联的设置。
当State.hbm.xml inverse = "false" cascade = "all"
- //添加
- //code
- StateDAO sdao =(StateDAO) ctx.getBean("stateDAO");
- AreaDAO adao = (AreaDAO)ctx.getBean("areaDAO");
- Area a3 = new Area();
- a3.setName("NewYork");
- Area a4 = new Area();
- a4.setName("Frolida");
- State s2 = new State();
- s2.setName("America");
- Set set = new HashSet();
- set.add(a3);
- set.add(a4);
- s2.setAreas(set);
- sdao.saveObject(s2);
- //sql:
- Hibernate
- : insert into r_state (name) values (?)
- Hibernate
- : insert into r_area (name, stateid) values (?, ?)
- Hibernate
- : insert into r_area (name, stateid) values (?, ?)
- Hibernate
- : update r_area set stateid=? where ID=?
- Hibernate
- : update r_area set stateid=? where ID=?
- //当State.hbm.xml inverse = "false" cascade = "none"(注意我们操作的是State)
- //sql: insert into r_state (name) values (?)
- Hibernate : update r_area set stateid=? where ID=?
- org.springframework.dao.InvalidDataAccessApiUsageException: object references an unsaved transient instance
这时候更新area的时候由于area,并未级联插入所以找不到报错。所以这样设置还是会更新Area的stateid
接着上面的说,我们要看当设置改变时的sql变化。
上面就说明了cascade="all" 时候能级联插入,而none的时候只是维持两者之间的关系(inverse ="false")。
上面两种情况的删除又不一样了,但是一个道理
cascade="all"时,两个表数据都级联删除了。
而cascade="none"时
Hibernate : update r_area set stateid=null where stateid=?
Hibernate : delete from r_state where ID=?说明它只是维持关系。
而当上面的inverse ="true"时 cascade="none"时
sql: insert into r_state (name) values (?)
只插入一条State,不会插入Area表了。
删除时
Hibernate : delete from r_state where ID=?
org.springframework.dao.DataIntegrityViolationException: (Hibernate operation): data integrity violated by SQL ''; nested exception is com.jnetdirect.jsql.u: DELETE 语句与 COLUMN REFERENCE 约束 'FKC7F1003A8EEBF16C' 冲突。该冲突发生于数据库 'hd',表 'r_area', column 'stateid'。
com.jnetdirect.jsql.u: DELETE 语句与 COLUMN REFERENCE 约束 'FKC7F1003A8EEBF16C' 冲突
由于没有维护数据库关系,引起外键冲突报错。
inverse ="true"时 cascade="all"时
sql:
Hibernate : insert into r_state (name) values (?)
Hibernate : insert into r_area (name, stateid) values (?, ?)
Hibernate : insert into r_area (name, stateid) values (?, ?)
全部级联插入,但r_area表中stateid是null。
删除时。
Hibernate : delete from r_area where ID=?
Hibernate : delete from r_area where ID=?
Hibernate : delete from r_state where ID=?
级联删除。
所以总结一下 ,cascade 是级联的程度,而inverse ="false|ture" 是指是否维持两个实体的关系。(两个表的外键)。
水平有限,请各位看客口下留情。
如果耽误了你的宝贵,我在这里道歉了。
发表评论
-
hibernate ehcache
2010-12-11 21:57 33861.EhCache是什么 EhCache是Hiberna ... -
全面讲解Hibernate二级缓存
2010-12-02 21:37 1180向大家详细介绍Hibernate ... -
深入理解Hibernate日志
2010-12-02 21:33 1924Hibernate中使用什么来记录日志呢?通常Hibern ... -
Hibernate中悲观锁和乐观锁
2010-12-02 21:19 3273Hibernate悲观锁:在数 ... -
解读Hibernate继承映射策略
2010-12-02 20:33 1097Hibernate继承映射的英文是Inheritanc ... -
mysql的text如何dialect mapping
2010-11-17 12:35 2324在开发项目中,遇到了hibernate 的2个bug。导致 ... -
让hibernate支持date_add
2010-11-17 12:30 5216今天做东西的时候想 ... -
Hibernate3一级缓存和二级缓存的理解!
2010-11-04 20:06 17081. Session 级别的缓存,它同 ... -
Hibernate的缓存机制
2010-10-26 21:24 1288核心提示:缓存是位于应用程序与物理数据源之间,用于临时存放 ... -
JPA注解学习总结
2010-10-26 21:02 4295核心提示:JPA 注解的几个要点 1.设置Pojo为实体 ... -
EHCache 缓存全接触
2010-10-26 21:01 2046EHCache 是一个纯java的,在Hibernate2.1 ... -
Hibernate的拦截器和监听器
2010-10-26 20:57 1497最近项目需要,用到了Hibernate的拦截器和监听器,有些小 ... -
Hibernate Shards 数据的水平、垂直切割 Hibernate测试环境
2010-10-24 11:15 1236http://www.cnblogs.com/RicCC/ar ... -
Java 开发 2.0: 使用 Hibernate Shards 进行切分
2010-10-24 11:10 1490当关系数据库试图在一 ... -
Hibernate Shards - 关系数据库水平分割解决方案框架
2010-10-24 10:41 33701。水平分割:按记录进分分割,不同的记录可以分开保存,每个子表 ... -
hibernate的保存
2010-04-21 17:43 2164hibernate的保存 hibernate对于对象的保存提 ... -
hibernate 调用存储过程
2010-02-07 14:05 7357第 17 章 Native SQL查询 你也可以使用 ...
相关推荐
### Hibernate中的Inverse属性详解 在Hibernate框架中,`inverse`属性是用于管理对象...通过上述实例分析,我们可以看到`inverse`属性在实际开发中的应用价值,以及它如何帮助我们构建更加健壮和高效的数据库应用。
在 Hibernate 中,级联操作(Cascade)和反向属性(Inverse)是管理对象关系的重要概念,特别是在处理一对多(One-to-Many)或多对一(Many-to-One)关系时。 **级联操作(Cascade)** 级联操作定义了当主对象被...
4. **inverse属性**:在Hibernate中,inverse属性用于指定关联的维护责任。C选项正确,表示在节点上,声明关联的维护由对方(many端)负责。 5. **级联操作**:在删除客户数据时希望同时删除相关订单,需要配置...
- **数据访问**:讨论PO(Persistent Object)和VO(Value Object)的区别,以及unsaved-value属性的作用,深入解析Inverse和Cascade机制,解释延迟加载(Lazy Loading)的原理和应用场景。 - **事务管理**:分析...
### Hibernate关联关系配置详解 ...总之,Hibernate提供了丰富的工具和方法来处理实体之间的关联关系,开发者可以根据实际需求选择合适的配置方式。理解这些关联关系的配置方式对于构建复杂的数据模型至关重要。
8. **实例分析**:以“一对多”为例,假设我们有一个User类,包含多个Order对象,User.hbm.xml中会配置一个`<set>`标签,Order.hbm.xml中则会配置一个`<many-to-one>`标签。在代码中,我们可以通过Session的get或...
### Hibernate的映射、三态、脏数据、Session缓存...通过上述分析可以看出,Hibernate通过强大的映射机制、状态管理机制、缓存机制等,大大简化了Java应用与数据库之间的交互过程,提高了开发效率和应用程序的性能。
通过上述分析,我们可以看到Spring、Hibernate和Struts这三个技术框架各自的优势以及它们之间的互补性。结合使用这些框架,可以构建出既强大又灵活的企业级应用程序。在实际开发过程中,开发者可以根据项目需求灵活...
本文将深入探讨“多对多”映射这一主题,结合老师与学生的实例,来解析其在实际应用中的实现和重要性。 “多对多”映射指的是两个实体之间存在多个关联,每个实体都可以与其他实体有多个关联。在我们的例子中,一个...
2. 分析A功能和B功能的代码,确保在处理每个请求时都使用了新的数据实例,而不是旧的数据。 3. 在处理B功能时,确保在事务中正确地操作了所有相关的数据库记录,包括清理不必要的临时状态。 4. 检查事务的边界,确保...
- **解析:** `inverse`和`cascade`是Hibernate中管理关联关系时使用的两个重要属性: - **inverse**:指定由哪一方负责维护关联关系。在双向关联中,通常一方设置为`true`,另一方设置为`false`。 - **cascade**...
Elasticsearch (ES) 是一个基于 Lucene 的搜索引擎,它提供了分布式、多租户能力的全文搜索引擎,能够处理海量数据的存储、检索和分析。在阿里云等云服务提供商中,ES 被广泛应用于日志分析、实时监控以及搜索场景。...
- **inverse**:关联关系的管理权。 - **cascade**:级联操作。 5. **Hibernate中的延迟加载** - **概念**:在真正需要时才加载关联对象。 - **用途**:提高性能,减少内存占用。 6. **Hibernate缓存机制** ...
2. **Object对象**:在面向对象编程中,对象是类的实例,拥有状态(属性)和行为(方法)。 3. **Relational关系**:指数据库中的表与表之间的关联关系,如一对多、多对一或多对多等。 4. **Mapping映射**:对象与...