本文研究的主要是
lazy的概念:在真正使用某个对象的时候才去加载该对象。
Hibernate的lazy策略可以使用在:
1.<class>标签上,可以取值:true/false。
2.<property>标签上,可以取值:true/false,需要类增强工具,对字节码进行修改(这个没多大意义)。
3.<set>和<list>标签上,可以取值:true/false/extra。
4.<many-to-one>和<one-to-one>单端关联标签上,可以取值:false/proxy/noproxy
下面我们来体会一下在class标签上的lazy:
User.java:
public class User {
/* ID */
private int id;
/* 用户名 */
private String name;
/* 用户密码 */
private String password;
/* 创建时间 */
private Date createTime;
//省略setter和getter方法
}
User.hbm.xml:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- package表示实体类的包名 -->
<hibernate-mapping package="com.lixue.bean">
<!-- class结点的name表示实体的类名,table表示实体映射到数据库中table的名称 -->
<class name="User" table="t_user" lazy="true">
<id name="id">
<generator class="native" />
</id>
<!-- 映射普通属性 -->
<property name="name" />
<property name="password" />
<property name="createTime" />
</class>
</hibernate-mapping>
测试方法:
public void testLoad1(){
/*获取User,load本身就支持延迟加载(class标签的lazy对普通属性有效)*/
User user = (User) HibernateUtils.getSession().load(User.class, 1);
/*不会发出sql(因为ID你查询的时候就已经指定了,没必要再去查)*/
System.out.println("user.id=" + user.getId());
/*会发出sql,因为此时真正要获取属性了,所以会发出sql语句,并且发出的语句查出了所有属性,后面的属性就不会发出语句了*/
System.out.println("user.name=" + user.getName());
/*不会发出sql(在查name的时候已经查出来了)*/
System.out.println("user.password=" + user.getPassword());
/*不会发出sql(在查name的时候就已经查出来了)*/
System.out.println("user.createTime=" + user.getCreateTime());
}
在User user = (User) HibernateUtils.getSession().load(User.class, 1);
处打一个断点进行测试!
对象会出现在对象user-->handler--->target结点中,如图:
1.最开始target为null,当执行了user.getId()
的时候,依然为null,因为ID在我们查询的时候就已经指定了,此时去查询就没什么意义。
2.执行user.getName()
的时候就发出了一条语句,如图:
从图中,我们可以看出,查询ID的时候,并没有发出语句,这个我们刚才已经讲了,当我们查询name属性的时候,就发了一条语句,并且这条语句的功能是查询所有的属性。
3.当执行user.getPassword()
和user.getCreateTime()
的时候,就已经不会发出语句了,因为之前已经查询出了属性值。
注:<class>标签上的lazy,只支持普通属性,不会影响类中集合的加载。
总结
以上就是本文关于Hibernate懒加载之<class>标签上的lazy的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!