Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 390|回复: 0

hibernate java.lang.IllegalArgumentException问题解决

[复制链接]
  • TA的每日心情
    奋斗
    4 天前
  • 签到天数: 789 天

    [LV.10]以坛为家III

    2049

    主题

    2107

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    722638
    发表于 2021-5-30 01:22:20 | 显示全部楼层 |阅读模式
    上周遇到了这个问题,参数异常,我以为是hibernate 的关系,结果换了JDBC来弄就好了,也没去深究到底是什么原因。今天又遇到这个问题了,和师父同时解决了这个问题。
    问题概述:
    在由数据库里的表反转实体(自动生成)之后,进行Hibernate查询,tomcat报java.lang.IllegalArgumentException参数异常。如下。
     1 2013-12-30 16:37:54 org.apache.catalina.core.StandardWrapperValve invoke
     2 严重: Servlet.service() for servlet struts threw exception
     3 java.lang.IllegalArgumentException
     4     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
     5     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
     6     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
     7     at java.lang.reflect.Method.invoke(Method.java:597)
     8     at org.hibernate.property.BasicPropertyAccessor$BasicSetter.set(BasicPropertyAccessor.java:66)
     9     at org.hibernate.tuple.entity.AbstractEntityTuplizer.setPropertyValues(AbstractEntityTuplizer.java:360)
    10     at org.hibernate.tuple.entity.PojoEntityTuplizer.setPropertyValues(PojoEntityTuplizer.java:221)
    11     at org.hibernate.persister.entity.AbstractEntityPersister.setPropertyValues(AbstractEntityPersister.java:3594)
    12     at org.hibernate.engine.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:152)
    13     at org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:877)
    14     at org.hibernate.loader.Loader.doQuery(Loader.java:752)
    15     at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:259)
    16     at org.hibernate.loader.Loader.doList(Loader.java:2228)
    17     at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2125)
    18     at org.hibernate.loader.Loader.list(Loader.java:2120)
    19     at org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:118)
    20     at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1596)
    21     at org.hibernate.impl.CriteriaImpl.list(CriteriaImpl.java:306)
    22     at cn.gx.lms.orgmanager.dao.CustomOrgManagerDaoImpl.queryLiftTypeDic(CustomOrgManagerDaoImpl.java:1924)
    23     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    24     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    25     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    26     at java.lang.reflect.Method.invoke(Method.java:597)
    27     at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:307)
    28     at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:182)
    29     at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:149)
    30     at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:106)
    31     at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171)
    32     at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204)
    33     at $Proxy22.queryLiftTypeDic(Unknown Source)
    34     at cn.gx.lms.orgmanager.service.CustomOrgManagerServiceImpl.queryLiftTypeDic(CustomOrgManagerServiceImpl.java:611)
    35     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    36     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    37     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    38     at java.lang.reflect.Method.invoke(Method.java:597)
    39     at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:307)
    40     at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:182)
    41     at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:149)
    42     at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:106)
    43     at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171)
    44     at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204)
    45     at $Proxy27.queryLiftTypeDic(Unknown Source)
    46     at cn.gx.lms.orgmanager.action.CustomOrgManagerAction.liftTypeAndScopeAdd(CustomOrgManagerAction.java:2114)
    47     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    48     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    49     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    50     at java.lang.reflect.Method.invoke(Method.java:597)
    51     at org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:269)
    52     at org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:170)
    53     at org.apache.struts.chain.commands.servlet.ExecuteAction.execute(ExecuteAction.java:58)
    54     at org.apache.struts.chain.commands.AbstractExecuteAction.execute(AbstractExecuteAction.java:67)
    55     at org.apache.struts.chain.commands.ActionCommandBase.execute(ActionCommandBase.java:51)
    56     at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
    57     at org.apache.commons.chain.generic.LookupCommand.execute(LookupCommand.java:304)
    58     at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
    59     at org.apache.struts.chain.ComposableRequestProcessor.process(ComposableRequestProcessor.java:283)
    60     at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913)
    61     at org.apache.struts.action.ActionServlet.doGet(ActionServlet.java:449)
    62     at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
    63     at javax.servlet.http.HttpServlet.service(HttpServlet.java:723)
    64     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    65     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    66     at cn.gx.lms.common.filter.CodeEncodeClass.doFilter(CodeEncodeClass.java:29)
    67     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    68     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    69     at cn.gx.lms.common.filter.AntiSqlInjectionfilter.doFilter(AntiSqlInjectionfilter.java:53)
    70     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    71     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    72     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    73     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    74     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:470)
    75     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    76     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
    77     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    78     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
    79     at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:861)
    80     at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:606)
    81     at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    82     at java.lang.Thread.run(Thread.java:619)

    在DAO层的检索如下(采用Criteria面向对象的检索):

     1 @SuppressWarnings("unchecked")
     2     @Transactional(propagation = Propagation.NOT_SUPPORTED)
     3     public List<LmsLiftTypeDic> queryLiftTypeDic(Map<String, String> conditions) {
     4         Criteria c = super.getSessionFactory().getCurrentSession()
     5                 .createCriteria(LmsLiftTypeDic.class);
     6         String dicType = conditions.get("dicType");
     7         if (StringUtil.validateStringNotNull(dicType)) {
     8             c.add(Restrictions.eq("dicType", dicType));
     9         }
    10         return c.list();
    11     }

    实体对应的hbm文件:

     1 <?xml version="1.0" encoding="utf-8"?>
     2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
     3 "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
     4 <!-- Mapping file autogenerated by MyEclipse Persistence Tools -->
     5 <hibernate-mapping>
     6     <class name="cn.gx.lms.domain.LmsLiftTypeDic" table="LMS_LIFT_TYPE_DIC">
     7         <id name="rowId" type="string">
     8             <column name="ROW_ID" length="32" />
     9             <generator class="uuid.hex" />
    10         </id>
    11         <property name="dicName" type="string">
    12             <column name="DIC_NAME" length="200" />
    13         </property>
    14         <property name="dicType" type="string">
    15             <column name="DIC_TYPE" length="1" />
    16         </property>
    17         <property name="orderNum" type="int">
    18             <column name="ORDER_NUM" />
    19         </property>
    20         <property name="createTime" type="date">
    21             <column name="CREATE_TIME" length="7" />
    22         </property>
    23         <property name="extends1" type="string">
    24             <column name="EXTENDS_1" length="200" />
    25         </property>
    26         <property name="extends2" type="date">
    27             <column name="EXTENDS_2" length="7" />
    28         </property>
    29         <property name="extends3" type="int">
    30             <column name="EXTENDS_3" />
    31         </property>
    32     </class>
    33 </hibernate-mapping>

     

     

     

    经测试,数据库中的number类型经Myeclipse的反向生成实体后,自动生成的类型为long,不可与之对应。将hbm文件和实体类中的long改为int对应的类型即可。目测是myeclipse的生成实体的问题,我再也不相信自动生成这回事儿了。。想省事,还是自己好好检查一番吧。

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-9-10 00:54 , Processed in 1.060089 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表