org.hibernate.HibernateException: HHH000142

本文解决了一个SSH框架下多表联合查询时出现的Hibernate延迟加载问题。通过调整Jar包版本、配置过滤器并正确使用查询方法,最终实现了稳定的查询功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ssh集成的时候,多表联合查询,报这个错误,通过打断点,找到是hibernate查询的时候出现这个错误,开始以为是延迟加载的问题,因为上一次和这个错误有点类似,是延迟加载的问题,就将loadAll改为find(query)的当时查询,还是报这个错误。百度了一下,看到有可能是jar包的冲突:只保留一个,建议保留较高版本,但是排查了过后还是没用(此时的没有Session已经配置过过滤器了)。只有最后的一招,清除环境变量,重新导入jar包,应为jar包的位置也会影响查找,比如早期 版本的Junit和 hamcrest 的位置。问题得到解决。

附代码:

过滤器的配置,注意位置,要在Struts上面

		<filter>
		<filter-name>OpenSessionInViewFilter</filter-name>
		<filter-class>org.springframework.orm.hibernate5.support.OpenSessionInViewFilter</filter-class>
	</filter>
	
	<filter-mapping>
		<filter-name>OpenSessionInViewFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>


配置过后,查询全体也可以用loadAll,毕竟loadAll比较方便,不会出现延迟加载的问题

List<User>list = this.getHibernateTemplate().loadAll(User.class);

但是查询具体的时候最好别用load,比如这个查询

this.getHibernateTemplate().get(Customer.class, cid);

用load的时候就会出现延迟加载的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值