我不能用ibatis调用一个过程。我收到无效的列索引错误。下面是代码,我跳过了myService实现。错误:-错误发生在ibatis/ployee.xml中。
-执行查询过程时出错。
-检查{ call GET_MY_INFO(#idNumber#,#result#) }。
-检查输出参数(寄存器输出参数失败)。
-原因: java.sql.SQLException:无效的列索引
<parameterMap id="getInfoCall" class="map">
<parameter property="idNumber" jdbcType="NUMERIC" mode="IN"/>
<parameter property="result" jdbcType="CURSOR" javaType="java.sql.ResultSet" mode="OUT"/>
</parameterMap>
<procedure id="getInfo" resultClass="MyClass" parameterMap="getInfoCall">
{ call GET_MY_INFO(#idNumber#,#result#) }
</procedure>MyClass.java:
public class MyClass{
private String name;
private String surname;
public String getName() {
return name;
}
public void setName(String name)
{
this.name=name;
}
public String getSurname()
{
return surname;
}
public void setSurname(String surname)
{
this.surname=surname;
}
}
HashMap<String,Object> params = new HashMap <String,Object>();
ResultSet rs = null;
params.put("idNumber", id.getValue());
params.put("result", rs);
ArrayList result;
result = (ArrayList) myService.getInfo(params);操作步骤:
DECLARE
ID_NUMBER NUMBER;
RESULT_P SYS_REFCURSOR;
BEGIN
ID_NO_P := ID_NUMBER;
RESULT_P := NULL;
GET_MY_INFO( ID_NUMBER, RESULT_P );
:rc0_P_CURSOR := RESULT_P;
END;resultMap版本:
<resultMap id="result" class="map" type="MyClass" >
<result property="name" column="NAME"/>
<result property="surname" column="SURNAME"/>
</resultMap>
<procedure id="getInfo" resultMap="result" parameterMap="getInfoCall">
{ call GET_MY_INFO(#idNumber#,#result#) }
</procedure>发布于 2019-02-20 17:05:40
这就是我的意思。这是你已经尝试过的吗?
<typeAlias alias=”myTypeAlias” type=”path.to.MyClass” />
<resultMap id="myResultMap" class="myTypeAlias" >
<result property="name" column="NAME"/>
<result property="surname" column="SURNAME"/>
</resultMap>
<parameterMap id="getInfoCall" class="map">
<parameter property="idNumber" jdbcType="NUMERIC" mode="IN"/>
<parameter property="result" resultMap="myResultMap" jdbcType="CURSOR" javaType="java.sql.ResultSet" mode="OUT"/>
</parameterMap>
<procedure id="getInfo" resultClass="MyClass" parameterMap="getInfoCall">
{ call GET_MY_INFO(#idNumber#,#result#) }
</procedure>https://stackoverflow.com/questions/54781587
复制相似问题