вызов процедуры iBatis - PullRequest
       14

вызов процедуры iBatis

0 голосов
/ 20 февраля 2019

Я не могу вызвать процедуру с 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>

1 Ответ

0 голосов
/ 20 февраля 2019

Вот что я имел в виду.Это то, что вы уже пробовали?

<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>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...