首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

无效的列部类(Invalid column type)

2013-01-28 
无效的列类型(Invalid column type)在一个Java WEB 项目中利用iBATIS调用一个ORACLE的存储过程。其中一个va

无效的列类型(Invalid column type)

在一个Java WEB 项目中利用iBATIS调用一个ORACLE的存储过程。其中一个varchar2类型in参数,三个number类型的out参数。
->在iBATIS配置文件中则定义 varchar2 参数的定义为
???????? jdbcType=”VARCHAR” javaType=”java.lang.String” mode=”IN”,
->而number类型的参数定义为
???????? jdbcType=”NUMBER” javaType=”java.math.BigDecimal” mode=”OUT”


结果报:
Check the output parameters (register output parameters failed).?
Cause: java.sql.SQLException: 无效的列类型
异常。


????? 后来查看java.sql.Types类中有关JDBC类型变量类型,并没有发“NUMBER”这一静态字段,而只有“NUMERIC”字段。(因此 jdbcType 的值不是数据库ORACLE的参数类型,而是其对应的JDBC变量类型)
但改了之后依然报同样错误。

??? 后来发现在java.sql.Types类中还有一个DECIMAL静态常量,与javaType定义的java.math.BigDecimal类型一致。再修改测试则通过,不再报错。

??? 所以“无效的列类型”异常解决方法,根据存储过程的参数类型找出正确的jdbcType(具体参考java.sql.Types类的JDBC静态变量)。

?

热点排行