No Dialect mapping for JDBC type :-9

用hibernate直接执行原生sql的查询,报错No Dialect mapping for JDBC type :-9。

在这里记录下,方便以后遇到同样的问题可以快速解决。

报错的代码如下:

String sql = "SELECT DIM_VALUE_FULL FROM DIMENSION_CALLREASON WHERE ID IN (:analyzeIds) ";

Query query = session.createSQLQuery(sql);
query.setParameterList("analyzeIds", analyzeIds);
 list = query.list();

报错原因:返回的服务器端的DIM_VALUE_FULL数据类型并不能和Java中的数据类型成功映射。

解决方法:规定返回值的类型

修正后的代码如下:

String sql = "SELECT DIM_VALUE_FULL FROM DIMENSION_CALLREASON WHERE ID IN (:analyzeIds) ";
Query query = session.createSQLQuery(sql).addScalar("DIM_VALUE_FULL", StandardBasicTypes.STRING);
query.setParameterList("analyzeIds", analyzeIds);
list = query.list();



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值