首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

Hibernate数据检索谋略

2012-10-15 
Hibernate数据检索策略Hibernate数据检索策略:??Hibernate的数据检索策略是面向对象的策略,对于不同的数据

Hibernate数据检索策略

Hibernate数据检索策略:

?

?

Hibernate的数据检索策略是面向对象的策略,对于不同的数据检索情况,应使用不同的策

?

?

略,以提高效率和节省资源。经常使用的是立即检索和延迟检索预先抓取是同一级别

?

?

的策略,因为它们是三选一的策略。用了其中一个则另外两个就都不可用,而且被延迟

?

加载的对象当最终被加载时,一定是使用立即加载的形式(指select 语句的形式).

?

批量检索可以优化立即和延迟加载,它们可以同时用。

?

?

立即检索的配置文件标识符为lazy=”false”.

?

对象的属性域、一对一关联对象、多对一关联对象,由于这些被关联的对象是”一”这

?

端,适合立即检索。而一对多和多对一关联对象则不适合设为立即检索.比如班级

?

和学生是一对多关系,当取得班级对象时,如果使用立即检索,就会把班级中所有学

?

生对象组装起来,然后把它们放入一个Set集合中,这个Set集合被班级对象引用。

Fetch=”join”

?

预先抓取指的是Hibernate通过select语句使用outer join (外连接,一般是左外连接left

?

outer join)来获得对象的关联实例或者关联集合。

?

?

它们之间的区别:

?

?

立即加载是立即填充附属物

?

延迟加载是只有实际使用到附属物时才会被填充。两者select语句形式是一样的,

?

都是通过id一条一条的查出来。

?

如果关联好多条记录,用立即检索或者延迟检索是不适合的。过多的sql语句必会造成

?

网络传输和响应的延迟,造成整体性能下降。使用预先抓取策略可以减少SQL语句

的条数。

实际使用中,一对多和多对多关系推荐使用延迟加载,而一对一和多对一关系

推荐使用预先加载。

?

?

Query? q=session.createQuery(“from? Student as s? left join? s.team”)

?

?

Stu.getTeam().getStudents().size() 会报LazyInitializationException异常。

?

这种指明HQL的方式,将忽略配置文件的所有策略。

?

将上面的HQL语句由左外连接改为预先抓取。

?

?

Query q=session.createQuery(“from? Student? as s ?left join fetch? s.team”)

??????

???????????

?? Hibernate仅在第一层关联时忽略配置文件的预先抓取,在更深的层次,按照配置文件设置的

?

策略取得对象。

?

批量加载

??????

??? 批量加载总是和立即或延迟加载联系在一起的,分为批量立即加载和批量延迟回载,可

?

以用于以下情况:

?

<set name=”students” inverse=”true” batch-size=”3”>

?

<key column=”team_id”/>

?

<one-to-many class=”model.Student”/>

?????

? </set>

?

<class name=”model.Team” table=”team” batch-size=”3”>

?

Query q=session.createQuery(“from Team t”);

?

?

如果在配置文件中设置了学生集合为batch-size=3,也就是批量加载学生集合的数量是3,如

?

果有100个班级,因为设置了批量加载,所以要加载100/3=33还有剩一个学生再加载一

?

?

次,共需要发送SQL语句34次。Batch-size设得太大,将会使延迟加载失去意义。

如果数据被设置了延迟加载,当此数据最终被加载进来时,也可以对它进行批量加载。

?

?

热点排行