模块隔离时引发的Hibernate问题

单向关联与双向关联
今天设计模块化的PO之间的隔离时,犯了晕,归纳了一下。

<one-to-many>与<many-to-one>的解析
模拟1:一个父亲有很多儿子,儿子只有一个父亲。

单向关联:
如果只指定<one-to-many>,由父类管理关联关系,子类无法管理,而这时,父亲知道自己的儿子,但是,从儿子对象不知道父亲是谁。
如果只指定<many-to-one>,则子类知道自己的父亲是谁,而父亲不知道孩子在哪里。
这二者的区别不是表结构的区别,而是逻辑上的差别,体现在具体语句上的差异。
另外,这里体现了cascade存在的意义:Cascade属性是来控制进行级联操作的。比如,单向关联<one-to-many>,父亲知道自己的孩子是谁,可以进行级联操作;但子类不清楚自己的父亲是谁,所以,不能进行级联操作的。

双向关联:
子和父都设置了<many-to-one>和<one-to-many>,那么,父亲知道孩子,孩子也知道父亲,也就是2者可以互相引用。。
这里就体现了inverse的意义:关联关系的管理可以通过inverse指定。

上面这些,表结构都相同,但是具体逻辑不同。

<many-to-many>的简析:显然,这2者均是双向关联,inverse和cascade的设置确定了双方的关系。
==============================
模块隔离的问题:
两个多对多的类,分别处于2个模块(A,B)中。模块A很基础,肯定存在;但部分情况下,模块B会不存在。如何拆分?
解决方案:
他们之间的关系,就不在PO层通过Hibernate实现(因为这样他们之间就存在耦合,导致2个模块不可拆分)。事实上,应该在Service层解决。
分析与方案如下:
1,逻辑上讲:模块A不知道模块B对它的关联,但模块B必须依赖与模块A
2,创建一个新的关联PO(LinkPO),相当于many-to-many情况下,Hibernate自动创建的中间表。该PO处于可移出的模块B内,
3,模块B提供一个接口,使得模块A可以获得模块B的相关数据;
4,当发生对这2个类之间的关系进行操作时,全部操作关联PO(LinkPO)

一对多的类,分别处于2个模块(A,B)中。模块关系同上。
相对简单了,不需要另外创建新的PO,只要在依赖而不是被依赖的模块内添加<many-to-one>就OK啦。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. Hibernate配置文件的位置和内容? Hibernate的配置文件名为hibernate.cfg.xml,一般放在src目录下。配置文件中包含了数据库连接信息、映射文件信息、缓存信息等。 2. Hibernate中如何进行事务操作? Hibernate的事务操作需要先开启事务,然后通过Session的操作完成数据库操作,最后提交或回滚事务。 3. Hibernate中如何进行对象关系映射? Hibernate通过XML配置文件或注解方式来进行对象关系映射。XML配置文件中需要指定对象与表的映射关系、属性与字段的映射关系等。 4. Hibernate中如何进行缓存管理? Hibernate提供了一级缓存和二级缓存。一级缓存是Session级别的缓存,二级缓存是SessionFactory级别的缓存。可以通过配置文件来启用二级缓存,并指定缓存策略。 5. Hibernate中如何进行延迟加载? Hibernate中可以通过在映射文件中指定lazy属性来进行延迟加载。当需要使用关联对象才会进行加载,避免了一次性加载所有数据的开销。 6. Hibernate中的懒加载有哪些问题Hibernate中的懒加载可能会导致N+1次查询问题,即在查询关联对象需要执行多次查询,造成性能问题。可以通过Fetch策略来解决该问题。 7. Hibernate中如何进行SQL查询? Hibernate中可以通过Criteria API或HQL来进行SQL查询。其中Criteria API提供了面向对象的查询方式,HQL则提供了类似SQL的查询语言。 8. Hibernate中如何进行连接池配置? Hibernate中可以通过配置文件来配置连接池。可以指定连接池大小、最大等待间、最大空闲间等参数。 9. Hibernate中如何进行多表查询? Hibernate中可以通过Criteria API或HQL来进行多表查询。可以通过关联查询、子查询等方式来实现多表查询。 10. Hibernate中如何进行分页查询? Hibernate中可以通过Criteria API或HQL来进行分页查询。可以指定每页的记录数、当前页数等参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值