hibernate多对一实体关联中,多方查询报空指针问题

针对Hibernate在AbstractEntityTuplizer.java:372处抛出的NullPointerException异常,本文介绍了两种有效的解决办法:升级cglib版本及修改关联对象的加载策略。

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

 hibernate中at org.hibernate.tuple.AbstractEntityTuplizer.createProxy(AbstractEntityTuplizer.java:372)异常的解决方法

 

java.lang.NullPointerException
at org.hibernate.tuple.AbstractEntityTuplizer.createProxy(AbstractEntityTuplizer.java:372)
 

在网上搜索答案时,给出的解决方案是:

1.导入cglib-2.2并替换掉cglib-2.13

2.将其关联的对象设置成lazy="false"

我采用的是第二种:即将  <many-to-one name="role" class="com.oaweb.bo.Role" fetch="select" >
            <column name="ROLEID" precision="10" scale="0" />
        </many-to-one>
        <many-to-one name="duty" class="com.oaweb.bo.Duty" fetch="select" >
            <column name="DUTYID" precision="10" scale="0" />
        </many-to-one>
        <many-to-one name="department" class="com.oaweb.bo.Department" fetch="select" >
            <column name="DEPTID" precision="10" scale="0" />
        </many-to-one>

改为:

  <many-to-one name="role" class="com.oaweb.bo.Role" fetch="select" lazy="false">
            <column name="ROLEID" precision="10" scale="0" />
        </many-to-one>
        <many-to-one name="duty" class="com.oaweb.bo.Duty" fetch="select" lazy="false">
            <column name="DUTYID" precision="10" scale="0" />
        </many-to-one>
        <many-to-one name="department" class="com.oaweb.bo.Department" fetch="select" lazy="false">
            <column name="DEPTID" precision="10" scale="0" />
        </many-to-one>

即可正常运行.

 

这个问题出得很莫名其妙,我单个表查询是是好的,如果是两个存在联系的表的话,如果你查询任何一个表都会有这个问题发现了两种解决方法:


1:主要说的是问题出在CGLib上面,修正一下就可以了,下载中也给出了patch,使用hibernate3.1把cglib从2.1.3更新到2.2.beta1。
2:设置相关表的lazy="false"解决问题。但是问题又出现了,到底是写在那个映射文件中呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值