我无法使用ibatis调用过程。我收到无效的列索引错误。这是代码,我跳过了myService实现。
错误:
---发生在ibatis / employee.xml中的错误。
---执行查询过程时发生错误。
---检查{通话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>
答案 0 :(得分:0)
这就是我的意思。这是您已经尝试过的吗?
<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>