Я не могу вызвать процедуру с ibatis.Я получаю неверную ошибку индекса столбца.Вот код, я пропускаю реализацию myService.ОШИБКА: --- Ошибка произошла в ibatis / employee.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>