Groovy Oracle Stored Proc - invaid列索引

时间:2017-02-28 22:09:47

标签: oracle jdbc groovy

sql.call("StoredProcName", [Sql.resultSet(OracleTypes.CURSOR)]) { table ->
        table.eachRow { row->
            println row
        }
    }

修改 这段代码给我一个invalid column index

此代码与我在网上看到的示例相同。我错过了什么?我可以不在游标上执行eachRow吗?这是我的过程

Create or Replace Procedure StoredProcName(cursor_ OUT SYS_REFCURSOR)
as
Begin
Open cursor_ For
Select blahblahblah

1 个答案:

答案 0 :(得分:1)

以下代码可以帮助您从Oracle匿名块中获取SYS_REFCURSOR的变量。

我们应该关注一些关键细节:

  1. 班级groovy.sql.Sql没有相应的OutParameter,我们将其手动设为CURSOR_PARAMETER并将其传递给sql.call方法
  2. 请注意,该块以{call DECLARE开头,以END }结尾,END后没有分号。否则,我们可以在脸上得到一个难以识别的SQLException
  3. ?内的问号sqlString是参数绑定的位置。绑定是以自然顺序进行的,取值为parametersList
    • 在此示例中,我们只有绑定,因此?与CURSOR_PARAMETER绑定,将值视为传递类型的OUT参数;
  4. sql.call之后只有一个进入闭包,ResultSet rs提供匿名块中声明的游标my_cur行。
  5. 我们可以通过使用函数返回sqlString而不是使用SYS_REFCURSOR参数的过程来简化OUT。所以它可能看起来像"{call BEGIN ? := MY_FUNC(); END}"甚至"{? = call MY_FUNC()}"
  6. import groovy.sql.OutParameter
    import groovy.sql.Sql
    import oracle.jdbc.OracleTypes
    
    import java.sql.ResultSet
    
    def driver = 'oracle.jdbc.driver.OracleDriver'
    def sql = Sql.newInstance('jdbc:oracle:thin:@my-server:1521:XXX', 'usr', 'psw', driver)
    
    // special OutParameter for cursor type
    OutParameter CURSOR_PARAMETER = new OutParameter() {
        public int getType() {
            return OracleTypes.CURSOR;
        }
    };
    
    // look at some ceremonial wrappers around anonymous block
    String sqlString = """{call
        DECLARE
          my_cur SYS_REFCURSOR;
        BEGIN
            STORED_PROCEDURE_NAME(my_cur);
            ? := my_cur;
        END
    }
    """;
    
    // the order of elements matches the order of bindings
    def parametersList = [CURSOR_PARAMETER];
    
    
    // rs contains the result set of cursor my_cur
    sql.call(sqlString, parametersList) { ResultSet rs ->
      while (rs.next()) {
          println rs.getString("my_column")
      }
    };
    

    P.S。谢谢你的提问。