查询方法如下:
public List find(String hql, Object... param) {
Query q = this.getCurrentSession().createQuery(hql);
if (param != null && param.length > 0) {
for (int i = 0; i < param.length; i++) {
q.setParameter(i, param[i]);
}
}
return q.list();
}
执行q.list()的时候,会报String不能转换为Integer错误,hibernate源码打进去跟了一下,截图见附件.
find方法的param中,第8个参数是一个很长的加密字符串,hibernate在处理这个的时候,用到OrdinalParameterDescriptor类,第8个参数是设置的的查询条件第八个的类型却是IntegerType.导致报类型转换异常.
我跟了半天也没找到是在什么时候初始化OrdinalParameterDescriptor类设置值的,有这块的高手能否解答一下.
hibernate用的4.1.5sp1.尝试用最新的4.2进去也会报这个错.

hibernate list查询 报类型转换异常
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- zyn010101 2013-08-13 13:49关注
第8个参数对应的实体字段是什么类型的?
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报