出乎意料的是,我开始在hibernate中收到“IllegalArgumentException:argument type mismatch”。 hibernate实体工作了很长时间,svn日志确认代码完好无损。
可能是什么情况?
这是异常的一部分
Jan 16, 2010 10:47:09 PM org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet Faces Servlet threw exception
java.lang.IllegalArgumentException: argument type mismatch
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.hibernate.property.BasicPropertyAccessor$BasicSetter.set(BasicPropertyAccessor.java:42)
at org.hibernate.tuple.entity.AbstractEntityTuplizer.setPropertyValues(AbstractEntityTuplizer.java:337)
at org.hibernate.tuple.entity.PojoEntityTuplizer.setPropertyValues(PojoEntityTuplizer.java:200)
at org.hibernate.persister.entity.AbstractEntityPersister.setPropertyValues(AbstractEntityPersister.java:3566)
at org.hibernate.engine.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:129)
at org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:854)
at org.hibernate.loader.Loader.doQuery(Loader.java:729)
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:236)
at org.hibernate.loader.Loader.doList(Loader.java:2220)
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2104)
at org.hibernate.loader.Loader.list(Loader.java:2099)
at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:378)
at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:338)
at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:172)
at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1121)
at org.hibernate.impl.QueryImpl.list(QueryImpl.java:79)
at org.springframework.orm.hibernate3.HibernateTemplate$30.doInHibernate(HibernateTemplate.java:930)
at org.springframework.orm.hibernate3.HibernateTemplate.doExecute(HibernateTemplate.java:419)
at org.springframework.orm.hibernate3.HibernateTemplate.executeWithNativeSession(HibernateTemplate.java:374)
at org.springframework.orm.hibernate3.HibernateTemplate.find(HibernateTemplate.java:921)
答案 0 :(得分:9)
翻译:Hibernate在尝试调用setter方法时提供了错误类型的参数。
我的第一步是找出哪个setter(例如通过在eclipse中调试应用程序,设置异常断点,并在达到断点时检查堆栈变量)。
编辑:映射属性qs
的setter的签名是什么?它应该是Set<Q>
。
答案 1 :(得分:3)
由于基础数据库字段更改(例如日期到时间戳),我听说过这种情况。如果您能够进行测试,或者像Sands建议的那样检查.hbm或注释,则可能值得恢复数据库更改。
答案 2 :(得分:3)
那么,你修改了一个hibernate映射文件而没有修改实体?我想那时qs
属性已经存在了。但它是java.util.Set
(正如您使用<set>
到map your collection)?
答案 3 :(得分:3)
解决方案是在查询执行中使用“ addScalar ”。
假设您的实体是用户:
@Entity
@Table(name="user")
@DynamicUpdate(value=true)
public class UserEntity implements Serializable{
@Id @GeneratedValue(strategy = GenerationType.AUTO)
@Column(name="id",updatable=false)
private Long id;
@Column(name="name",nullable=false,length=20)
private String name;
....
}
而不是:
List<UserEntity> users = sessionFactory.getCurrentSession()
.createQuery(query)
.list();
使用addScalar:
List<UserEntity> users = sessionFactory.getCurrentSession()
.createQuery(query)
.addScalar("id",LongType.INSTANCE)
.addScalar("name",StringType.INSTANCE)
.list();
注意:在LongType.INSTANCE之前,有Hibernate.LONG和Hibernate.STRING(现在已弃用)。
答案 4 :(得分:0)
有时它会在类型不兼容时发生。对于MySQL查询,必须进行转换后才能进行兼容。
select CAST(sum(hours) AS SIGNED) ...
希望这会帮助人们遇到与JPA类似的问题(JPA-Hibernate for exact)。