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

解决方案 »

  1.   

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

  2.   

    jdbcType="varchar2" 错了  jdbcType="VARCHAR"jdbc里面没有varchar2 这里的VARCHAR不是数据库类型,是指java.sql.Types.VARCHAR
      

  3.   

    谢谢 懒猫  & 狂浪, 都说到了问题, 懒猫更准确一点, 但是最后我解决的方法还有一个重要的步骤,更新了ibatis。jar包   ibatis-2.3.4.726.jar  这样才基本正确。也许懒猫的也正确。