日期:2014-05-16  浏览次数:20960 次

ibatis oracle 调用存储过程 无法取得返回值
java 
   Map map = new HashMap();
   map.put("respCode", "100");
   getSqlMapClientTemplate().insert("getPhotos",map);
   return (String)map.get("respCode");
-----------------------
xml
  <parameterMap class="map" id="swapParameters">       
     <parameter property="respCode"  javaType="java.lang.String" jdbcType="varchar2" mode="OUT"/>  
</parameterMap>   
  <procedure id="getPhotos" parameterMap="swapParameters" >
       {call getPhoto(?)}
    </procedure>
---------------------------
oracle sql
create or replace procedure getPhoto(respCode out varchar2)
as
begin
  respCode := 'aaa';
end;

===============================================================
org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation: encountered SQLException [  
--- The error occurred in com/rm/yjzq/dao/impl/sql/yjzq.xml.  
--- The error occurred while executing update procedure.  
--- Check the {call getPhoto(?)}.  
--- Check the output parameters (register output parameters failed).  
--- Cause: java.sql.SQLException: 无效的列类型: -99999999]; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:   
--- The error occurred in com/rm/yjzq/dao/impl/sql/yjzq.xml.  
--- The error occurred while executing update procedure.  
--- Check the {call getPhoto(?)}.  
--- Check the output parameters (register output parameters failed).  
--- Cause: java.sql.SQLException: 无效的列类型: -99999999
com.ibatis.common.jdbc.exception.NestedSQLException:   
--- The error occurred in com/rm/yjzq/dao/impl/sql/yjzq.xml.  
--- The error occurred while executing update procedure.  
--- Check the {call getPhoto(?)}.  
--- Check the output parameters (register output parameters failed).  
--- Cause: java.sql.SQLException: 无效的列类型: -99999999


求高手急救,在网上找了很多的例子,但是都不是正确的,只好发帖求教。
原来是一个入参一个出参,现在直接出参还是不对。

------解决方案--------------------
对java不是很了解。不过这里看起来,本来应该用一个变量来获取存储过程中传出参数respCode的值,但你的?这里不能代表一个变量吧
这个地方还不如改成函数
------解决方案--------------------
jdbcType="varchar2" 错了  jdbcType="VARCHAR"

jdbc里面没有varchar2 这里的VARCHAR不是数据库类型,是指java.sql.Types.VARCHAR
我的异常网推荐解决方案:oracle存储过程,http://www.aiyiweb.com/oracle-develop/177537.html