load()方法与get()方法不同,get()即使Session关闭之后,也可以使用对象,而load()方法在Session关闭之后,会出现懒加载的问题,出现的问题如下:
这个问题解决方法如下:
找到你的XXX.hbm.xml在class中加入一个属性:lazy,lazy的内容为false,如下:
<class name="com.entity.user" table="USER" lazy="false">
<id name="id" type="java.lang.String">
<column name="ID" />
<generator class="assigned" />
</id>
<property name="name" type="java.lang.String">
<column name="NAME" />
</property>
<property name="pwd" type="java.lang.String">
<column name="PWD" />
</property>
</class>
无论是load还是get,都会查找缓存(一级缓存),如果没有才会去数据库查找,调用clear()方法强制清除session缓存,使用代码如下:
@Test
public void clear() {
user t = (user) session.get(user.class, "123");
System.out.println(t.getName());
//clear()方法用来清除session的缓存
session.clear();//这里不clear只会执行一次sql语句,有clear会执行2次
user t2 = (user) session.get(user.class, "123");
System.out.println(t2.getName());
}