hibernate java.lang.IllegalArgumentException問題解決


上周遇到了這個問題,參數異常,我以為是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的生成實體的問題,我再也不相信自動生成這回事兒了。。想省事,還是自己好好檢查一番吧。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM