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方案。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)