读书人

ibatis调用存储过程,参数未out类型时的

发布时间: 2013-03-26 21:10:11 作者: rapoo

ibatis调用存储过程,参数未out类型时的典型错误
在一个Java WEB 项目中利用iBATIS调用一个ORACLE的存储过程。其中一个varchar2类型in参数,三个number类型的out参数。在iBATIS配置文件中则定义 varchar2 参数的定义为

Check the output parameters (register output parameters failed).  Cause: java.sql.SQLException: 无效的列类型 

异常。

后来查看java.sql.Types类中有关JDBC类型变量类型,并没有“NUMBER”这一静态字段,而只有“NUMUBERIC”字段。(因此 jdbcType 的值不是数据库ORACLE的参数类型,而是其对应的JDBC变量类型)

但改了之后依然报同样错误。

后来发现在java.sql.Types类中还有一个DECIMAL静态常量,与javaType定义的java.math.BigDecimal类型一致。

再修改测试则通过,不再报错。

所以“无效的列类型”异常解决方法,根据存储过程的参数类型找出正确的jdbcType(具体参考java.sql.Types类的JDBC静态变量)。
我的异常网推荐解决方案:oracle存储过程,http://www.myexception.cn/oracle-develop/177537.html

读书人网 >软件架构设计

热点推荐