java - iBatis 过程调用

标签 java procedure ibatis

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

最佳答案

这就是我的意思。这是您已经尝试过的吗?

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

关于java - iBatis 过程调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54781587/

相关文章:

php - 从 postgresql 后端的存储过程中检索通知

java - mybatis RuntimeSQLException 与 SqlSessionException

java - 在每种情况下都使用具有一系列值的 switch 语句?

java - 链接方法/小修正 - Java

oracle - PL/SQL : Retrieve names of procedures and functions within a package

java - Ibatis中如何使用SqlMap映射多条记录

java - SQL 会受到注释的影响吗?

java - Spring 启动: The Tomcat connector configured to listen on port 8080 failed to start

java - PathVariable 根本不起作用

java:获取 sqlexception 消息 "incorrrect syntax near ' {' "