`
cjh820425
  • 浏览: 155891 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

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

阅读更多

今天在做Hibernate多对一查询时,一方查询正常,但多方查询出错.出错的异常信息为:
javax.servlet.ServletException: java.lang.NullPointerException
org.apache.struts.action.RequestProcessor.processException(RequestProcessor.java:535)
org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:433)
org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:236)
org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196)
org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432)
javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
com.oaweb.filter.EncodingFilter.doFilter(EncodingFilter.java:23)


root cause

java.lang.NullPointerException
org.hibernate.tuple.AbstractEntityTuplizer.createProxy(AbstractEntityTuplizer.java:372)
org.hibernate.persister.entity.AbstractEntityPersister.createProxy(AbstractEntityPersister.java:3121)
org.hibernate.event.def.DefaultLoadEventListener.createProxyIfNecessary(DefaultLoadEventListener.java:232)
org.hibernate.event.def.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:173)
org.hibernate.event.def.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:87)
org.hibernate.impl.SessionImpl.fireLoad(SessionImpl.java:862)
org.hibernate.impl.SessionImpl.internalLoad(SessionImpl.java:830)
org.hibernate.type.EntityType.resolveIdentifier(EntityType.java:266)
org.hibernate.type.EntityType.resolve(EntityType.java:303)
org.hibernate.engine.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:116)
org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:842)
org.hibernate.loader.Loader.doQuery(Loader.java:717)
org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:224)
org.hibernate.loader.Loader.doList(Loader.java:2145)
org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2029)
org.hibernate.loader.Loader.list(Loader.java:2024)
org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:375)
org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:308)
org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:153)
org.hibernate.impl.SessionImpl.list(SessionImpl.java:1106)
org.hibernate.impl.QueryImpl.list(QueryImpl.java:79)
com.oaweb.dao.impl.UserDAO.findPassword(UserDAO.java:26)
com.oaweb.service.impl.UserService.findPassword(UserService.java:29)
com.oaweb.struts.action.UserAction.register(UserAction.java:59)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
java.lang.reflect.Method.invoke(Method.java:589)
org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:270)
org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:187)
org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:431)
org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:236)
org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196)
org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432)
javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
com.oaweb.filter.EncodingFilter.doFilter(EncodingFilter.java:23)
note The full stack trace of the root cause is available in the Apache Tomcat/6.0.14 logs.

 

Hibernate中Userinfo实体映射文件:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="com.oaweb.bo.Userinfo" table="USERINFO" schema="OAWEB">
        <id name="userid" type="java.lang.Long">
            <column name="USERID" precision="10" scale="0" />
            <generator class="sequence" >
            <param name="sequence">seq1</param>
            </generator>
        </id>
        <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>
        <property name="username" type="java.lang.String">
            <column name="USERNAME" length="20" not-null="true" />
        </property>
        <property name="realname" type="java.lang.String">
            <column name="REALNAME" length="20" not-null="true" />
        </property>
        <property name="userpassword" type="java.lang.String">
            <column name="USERPASSWORD" length="32" not-null="true" />
        </property>
        <property name="question" type="java.lang.String">
            <column name="QUESTION" length="50" not-null="true" />
        </property>
        <property name="answer" type="java.lang.String">
            <column name="ANSWER" length="50" not-null="true" />
        </property>
        <property name="usersex" type="java.lang.String">
            <column name="USERSEX" length="4" not-null="true" />
        </property>
        <property name="userage" type="java.lang.Long">
            <column name="USERAGE" precision="2" scale="0" />
        </property>
        <property name="usernation" type="java.lang.String">
            <column name="USERNATION" length="20" />
        </property>
        <property name="userstature" type="java.lang.String">
            <column name="USERSTATURE" length="5" />
        </property>
        <property name="bornaddress" type="java.lang.String">
            <column name="BORNADDRESS" length="60" />
        </property>
        <property name="borndate" type="java.util.Date">
            <column name="BORNDATE" length="7" />
        </property>
        <property name="mobiltel" type="java.lang.String">
            <column name="MOBILTEL" length="20" />
        </property>
        <property name="worktel" type="java.lang.String">
            <column name="WORKTEL" length="20" />
        </property>
        <property name="address" type="java.lang.String">
            <column name="ADDRESS" length="100" />
        </property>
        <property name="mailno" type="java.lang.String">
            <column name="MAILNO" length="6" />
        </property>
        <property name="email" type="java.lang.String">
            <column name="EMAIL" length="30" />
        </property>
        <property name="hometel" type="java.lang.String">
            <column name="HOMETEL" length="20" />
        </property>
        <property name="workdate" type="java.util.Date">
            <column name="WORKDATE" length="7" />
        </property>
        <property name="userstatus" type="java.lang.String">
            <column name="USERSTATUS" length="10" />
        </property>
        <property name="politician" type="java.lang.String">
            <column name="POLITICIAN" length="10" />
        </property>
        <property name="college" type="java.lang.String">
            <column name="COLLEGE" length="60" />
        </property>
        <property name="speciality" type="java.lang.String">
            <column name="SPECIALITY" length="60" />
        </property>
        <property name="collegegrade" type="java.lang.String">
            <column name="COLLEGEGRADE" length="16" />
        </property>
        <property name="englishgrade" type="java.lang.String">
            <column name="ENGLISHGRADE" length="40" />
        </property>
        <property name="itgrade" type="java.lang.String">
            <column name="ITGRADE" length="40" />
        </property>
    </class>
</hibernate-mapping>

在查询Department,Duty,Role时均正常.查询Userinfo时,报

java.lang.NullPointerException
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>

即可正常运行.

分享到:
评论

相关推荐

    S变换+Sockwell R G , Mansinha L , Lowe R P . Localization of the complex spectrum: the S transformJ

    s变换用的高斯窗函数( 高斯窗是指数窗的一种,它也无负的旁瓣,而且没有旁瓣波动,因而不回引起计算谱中假的极大值或极小值,而且高斯窗频率窗函数的主瓣比指数窗的主瓣窄,分辨率比指数窗有所提高。

    2021科大讯飞车辆贷违预测大赛冠军源码+全部资料.zip

    2021科大讯飞车辆贷违预测大赛冠军源码+全部资料.zip [资源说明] 1、该项目是团队成员近期最新开发,代码完整,资料齐全,含设计文档等 2、上传的项目源码经过严格测试,功能完善且能正常运行,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的高校学生、教师、科研工作者、行业从业者下载使用,可借鉴学习,也可直接作为毕业设计、课程设计、作业、项目初期立项演示等,也适合小白学习进阶,遇到问题不懂就问,欢迎交流。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 5、不懂配置和运行,可远程教学 欢迎下载,学习使用!

    AI图像处理工具包-一键抠图、背景切换、旧照片修复、人像漫画化、视频卡通化(Python+OpenCV+Dlib+TensorFlow).zip

    AI图像处理工具包-一键抠图、背景切换、旧照片修复、人像漫画化、视频卡通化(Python+OpenCV+Dlib+TensorFlow).zip [资源说明] 1、该项目是团队成员近期最新开发,代码完整,资料齐全,含设计文档等 2、上传的项目源码经过严格测试,功能完善且能正常运行,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的高校学生、教师、科研工作者、行业从业者下载使用,可借鉴学习,也可直接作为毕业设计、课程设计、作业、项目初期立项演示等,也适合小白学习进阶,遇到问题不懂就问,欢迎交流。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 5、不懂配置和运行,可远程教学 欢迎下载,学习使用!

    基于java+springboot+vue+mysql的远程教育网站设计与实现.docx

    基于java+springboot+vue+mysql的远程教育网站设计与实现.docx

    springboot005学生心理咨询评估系统(源码+数据库+论文+PPT+包调试+一对一指导)

    毕业设计资料,计算机毕业设计,源码,毕业论文,毕业答辩,答辩PPT,Java毕业设计,php毕业设计,ASP.NET毕业设计,毕业指导,计算机作业,php作业,java作业,ASP.NET作业,编程作业,管理系统,网站,app,毕业设计学习,Java学习,php学习,ASP.NET学习,java课程,php课程,ASP.NET课程,答辩技巧,SQLSERVER数据库,Mysql数据库,jdbc,SSM框架,SpringBoot框架,Html5,小程序

    蓝牙串口助手,可以连接HC-05等蓝牙模块,实现单片机设备与手机通讯,安卓手机,蓝牙调试助手,具有按键功能!

    蓝牙串口助手,可以连接HC-05等蓝牙模块,实现单片机设备与手机通讯,安卓手机,蓝牙调试助手,具有按键功能!

    TriLib-2-Model-Loading-Package-2.3.7.unitypackage

    TriLib 2 是一个跨平台的运行时 3D 模型导入器

    “人力资源+大数据+薪酬报告+涨薪调薪”

    人力资源+大数据+薪酬报告+涨薪调薪,在学习、工作生活中,越来越多的事务都会使用到报告,通常情况下,报告的内容含量大、篇幅较长。那么什么样的薪酬报告才是有效的呢?以下是小编精心整理的调薪申请报告,欢迎大家分享。相信老板看到这样的报告,一定会考虑涨薪的哦。

Global site tag (gtag.js) - Google Analytics