Hibernate延迟加载问题

简介: Hibernate的映射配置单如下: DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.

Hibernate的映射配置单如下:

<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class name="ext.eclipse.ide.auth.role.impl.UserImpl" table="Users">
        <id name="id">
            <column name="UID" length="15" />
        </id>
        <property name="name">
            <column name="NAME" length="20" />
        </property>
        <property name="password">
            <column name="PASSWORD" length="64" />
        </property>
        <set name="roles" table="User_Role" cascade="all-delete-orphan" fetch="join">
            <key column="USER_ID"></key>
            <many-to-many class="ext.eclipse.auth.role.impl.RoleImpl"
                column="ROLE_ID"></many-to-many>
        </set>
    </class>
</hibernate-mapping>

可以看到,UserImpl和RoleImpl是many-to-many的关系,关系Set维护在UserImpl的roles属性中。

set标签没有写lazy="false"属性,即是懒加载被设定为默认的true,这表示:

当同一个事务对UserImpl进行查询的时候,如果roles没有被使用到,是不会对User_Role关系表查询的。

很明显,这是为了提高效率。

 

我对Session进行了封装:

    public List<?> query(String hql) {
        Session session = getSessionFactory().getCurrentSession();

        session.beginTransaction();
        Query query = null;
        try {
            query = session.createQuery(hql);
        } catch (Exception e) {
            e.printStackTrace();
        }
        List<?> result = query == null ? new ArrayList<Object>() : query.list();
        session.getTransaction().commit();

        return result;
    }

 

按照以上的代码,如果我调用

query("from UserImpl");

获取UserImpl对象,当调用到user.getRoles()的时候,是会抛出懒加载异常的(Session不存在或者已经关闭)

 

解决办法有四:

1、提供Session出来,单独写一个包含getRoles的查询

2、使用Hibernate.initialize(Object proxy)方法,强制加载

3、在配置文件里设置lazy="false"(明显不可取)

4、为配置文件增加fetch="join",然后hql改为“from UserImpl ui left join fetch ui.roles”

 

推荐4方案。

 

 

目录
相关文章
|
17天前
|
Java 数据库连接 数据库
【Mybatis】mybatis 是否支持延迟加载?
【Mybatis】mybatis 是否支持延迟加载?
|
2月前
|
存储 缓存 Java
【MyBaits】4、延迟加载、MyBatis 的缓存
【MyBaits】4、延迟加载、MyBatis 的缓存
23 0
|
4月前
|
Java 数据库连接 mybatis
Mybatis中延迟加载~
Mybatis中延迟加载~
|
Java 数据库连接 数据库
【MyBatis】学习笔记13:延迟加载(懒加载)
【MyBatis】学习笔记13:延迟加载(懒加载)
110 0
【MyBatis】学习笔记13:延迟加载(懒加载)
|
Java 数据库连接 数据库
mybatis学习(55):延迟加载
mybatis学习(55):延迟加载
86 0
|
SQL Java 数据库连接
Mybatis延迟加载策略
Mybatis延迟加载策略
Mybatis延迟加载策略
|
SQL Java 数据库连接
MyBatis入门-延迟加载与立即加载
MyBatis入门-延迟加载与立即加载
226 0
MyBatis入门-延迟加载与立即加载
|
SQL Java 数据库连接
【MyBatis框架点滴】——MyBatis延迟加载
 延迟加载(lazy load)是(也称为懒加载)Hibernate3关联关系对象默认的加载方式,延迟加载机制是为了避免一些无谓的性能开销而提出来的,所谓延迟加载就是当在真正需要数据的时候,才真正执行数据加载操作。——摘自百度百科《延迟加载》
【MyBatis框架点滴】——MyBatis延迟加载
|
SQL Java 数据库连接
Mybatis:高级知识2- 延迟加载
Mybatis:高级知识2- 延迟加载
187 0
Mybatis:高级知识2- 延迟加载
|
SQL 存储 缓存
Mybatis学习第四天:Mybatis延迟加载懒加载,一级缓存,二级缓存,注解开发
Mybatis学习第四天:Mybatis延迟加载懒加载,一级缓存,二级缓存,注解开发
Mybatis学习第四天:Mybatis延迟加载懒加载,一级缓存,二级缓存,注解开发