hibernate集合的加载策略

在集合方配置lazy和fetch的方式,默认的是lazy为true,fetch为select,lazy有true,extra和false,true和extra都是懒加载,只是extra比true更懒,区别就是extra加载集合list.size()时只发送count(*)加载仅仅一个总数,其他情况和true没有区别,为true/extra时需要注意session不要关闭,不然后续的集合属性获取就没法获取了,会报no session的错误,而fetch有select,join,subselect3种,其实也就是去数据库中获取数据时发送sql的形式不同,select为分开单独用查询对象和集合,而join为以对象为主的left join一起关联查询出来,此时lazy为true已经失效,这些配置适用于对象导航查询和QBC查询,因为对象导航查询无需自己写sql,所以Hibernate默认会根据配置的方式决定发送sql的形式,如果是HQL语句查询,这些配置没啥卵用,一般情况不需要自己额外进行配置这两个属性,以免出现麻烦,需要配置的也就是一个是否放弃外键维护inverse="true",其他的建议一概使用默认。Hibernate查询方式根据程序员指定的hql语句进行查询,如hql中写了left join后那么Hibernate就按照left join进行查询,如果没写left join默认按照select单表查询,需要注意的是hql用left关联查询时,如果不写fetch那么返回的是两个对象而不是以属性组装的形式返回

		<set name="linkmans" inverse="true" lazy="true"  fetch="select">
			<key column="lkm_cust_id"/>
			<one-to-many class="com.cb.pojo.Linkman"/>
		</set>

left join的fetch抓取,注意不用写on条件,但是得有别名进行关联

from Customer c left join fetch c.linkmans

  

  

posted @ 2017-08-12 11:15  关键步就几步  阅读(140)  评论(0编辑  收藏  举报