iBatis程序调用

时间:2019-02-20 08:11:03

标签: java procedure ibatis

我无法使用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>

1 个答案:

答案 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>