hibernate list查询 报类型转换异常

查询方法如下:
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进去也会报这个错.

第8个参数对应的实体字段是什么类型的?

是不是你的实体类属性类型弄错了?

你这样很容易出现问题,由于与参数个数占位符有关,所以当不同的条件时候,同一个hql语句参数位置会不一样,一般的写法如下:
String hql = "from Stock s where s.stockCode = :stockCode";
List result = session.createQuery(hql)
.setString("stockCode", "7277")
.list();
这个是基于name的,而你的是基于jdbc的?占位符.所以会出现这样的问题