Hibernate级联关系的说明和优化

今天接到一个公司的电话面试,里面问道Hibernate的级联,很失败,竟然回答的吞吞吐吐的,失败。前几天刚刚做了,看开做东西要仔仔细细,马虎问题大。

说说级联吧:

========================INVERSE===============================

Hibernate里面的inverse有两个值true,false;

inverse的意思是翻转,这里面理解为对对应表的的维护

http://space.itpub.net/22259926/viewspace-631423

里面说的,如果inverse为false的化,delete不会修改order表单,即对应关系没有维护。但是新增的时候,会增加order表单,

下面是转载的,

========================CASCADE===========================

cascade有五个选项分别是:all,delete,none,save-update,delete-orphan;

all:所有情况下均进行关联操作。

none:所有情况下均不进行关联操作。这是默认值。

save-update:在执行save/update/saveOrUpdate时进行关联操作。

delete:在执行delete时进行关联操作。

delete-orphan:当save/update/saveOrUpdate时,相当于save-update;当删除操作时,相当于delete;

all的意思是save-update+delete

all-delete-orphan的意思是当对象图中产生孤儿节点时,在数据库中删除该节点

all比较好理解,举个例子说一下all-delete-orphan:

Category与Item是一对多的关系,也就是说Category类中有个Set类型的变量items.

举个例子,现items中存两个Item,item1,item2,如果定义关系为all-delete-orphan

当items中删除掉一个item(比如用remove()方法删除item1),那么被删除的Item类实例

将变成孤儿节点,当执行category.update(),或session.flush()时

hibernate同步缓存和数据库,会把数据库中item1对应的记录删掉

========================LAZY===========================

结论1:HQL代码>fetch(配置)>lazy(配置)

结论2:默认lazy="true"

结论3:fetch和lazy主要是用来级联查询的,

fetch参数指定了关联对象抓取的方式是select查询还是join查询,select方式时先查询返回要查询的主体对象(列表),再根据关联外键id,每一个对象发一个select查询,获取关联的对象,形成n+1次查询;而join方式,主体对象和关联对象用一句外键关联的sql同时查询出来,不会形成多次查询。

如果你的关联对象是延迟加载的,它当然不会去查询关联对象。另外,在hql查询中配置文件中设置的join方式是不起作用的(而在所有其他查询方式如get、criteria或再关联获取等等都是有效的),会使用select方式,除非你在hql中指定joinfetch某个关联对象。fetch策略用于定义get/load一个对象时,如何获取非lazy的对象/集合。这些参数在Query中无效。

========================batch-size==============================

今天有个问题,就是一对多查询时候,比如Customer里面包含了太多Order表单怎么优化?当时懵了

其实可以使用Hibernate的延迟加载功能,即时Lazy=true,只有在真正需要的时候,才去从数据库加载“本体”,Customer的某个Order,只用当该Order真正需要时候的,采取从数据库加载

相关推荐