JAVA ibatis 调用oracle存储过程报错,请各位帮忙看看啊,搞了一天了。不过我没分,希望大家慷慨相助。

没有增加输出参数时没问题,加了就一直报错IBATIS配置<parameterMapclass="java.util.Map"id="tableTempl"><parame... 没有增加输出参数时没问题,加了就一直报错

IBATIS配置
<parameterMap class="java.util.Map" id="tableTempl">

<parameter property="p_sc_user_id" jdbcType="number"
javaType="java.lang.String" mode="IN" />
<parameter property="p_sc_class_id" jdbcType="number"
javaType="java.lang.String" mode="IN" />
<parameter property="p_remarks" jdbcType="varchar"
javaType="java.lang.String" mode="IN" />
<parameter property="p_created_by" jdbcType="varchar"
javaType="java.lang.String" mode="IN" />
<parameter property="errorcode" jdbcType="varchar"
javaType="java.lang.String" mode="INOUT" />
</parameterMap>
<!-- 自定一个sqlmap-ID parameterMap指定为上面定义的map(重要)-->
<procedure id="SP_SysClientBaseTempTable" parameterMap="tableTempl">
<!-- <![CDATA[ 语句 ]]> 其中:<![CDATA[ ]]> 最好不要换行-->
<![CDATA[{call insertclass(?,?,?,?,?)}]]>
</procedure>
JAVA类
//调存储过程
public String updateStudent(Student student) {
Map map = new HashMap();
map.put("p_sc_user_id", student.getSc_user_id());
map.put("p_sc_class_id", student.getSc_class_id());
map.put("p_remarks", student.getRemarks());
map.put("p_created_by", student.getCreated_by());
map.put("errorcode","0");
try {
con.getSqlMap().queryForObject("SP_SysClientBaseTempTable",map);
System.out.print(map.get("errorcode").toString());
} catch (SQLException e) {
e.printStackTrace();
return map.get("errorcode").toString();
}
return map.get("errorcode").toString();
}
测试主函数:
public static void main(String[] args) {
Sdao dao=new Sdao();
Student ss = new Student();
ss.setSc_user_id("1");
ss.setSc_class_id("5");
ss.setRemarks("0802");
ss.setCreated_by("xx");

dao.updateStudent(ss);
}
这里是部分错误信息
com.ibatis.common.jdbc.exception.NestedSQLException:
--- The error occurred in com/test0507/struts/dx/UserBean.xml.
--- The error occurred while executing query procedure.
--- Check the {call insertclass(?,?,?,?,?)}.
--- Check the output parameters (register output parameters failed).
--- Cause: java.sql.SQLException: 无效的列类型
Caused by: java.sql.SQLException: 无效的列类型
at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.executeQueryWithCallback(GeneralStatement.java:185)
at com.ibatis.sqlmap.engine.mapping.statement.GeneralStatement.executeQueryForObject(GeneralStatement.java:104)
at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForObject(SqlMapExecutorDelegate.java:561)
at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.queryForObject(SqlMapSessionImpl.java:93)
at com.ibatis.sqlmap.engine.impl.SqlMapClientImpl.queryForObject(SqlMapClientImpl.java:70)
展开
 我来答
王年明
2012-08-11
知道答主
回答量:5
采纳率:0%
帮助的人:8020
展开全部
ibaits没有用过,hibernate 用过。都是走持久化的,主要是XML配置文件。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式