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

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