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
答案 0 :(得分:1)
以下代码可以帮助您从Oracle匿名块中获取SYS_REFCURSOR
的变量。
我们应该关注一些关键细节:
groovy.sql.Sql
没有相应的OutParameter
,我们将其手动设为CURSOR_PARAMETER
并将其传递给sql.call
方法{call DECLARE
开头,以END }
结尾,END后没有分号。否则,我们可以在脸上得到一个难以识别的SQLException
。?
内的问号sqlString
是参数绑定的位置。绑定是以自然顺序进行的,取值为parametersList
。
?
与CURSOR_PARAMETER绑定,将值视为传递类型的OUT
参数; sql.call
之后只有一个进入闭包,ResultSet rs
提供匿名块中声明的游标my_cur
行。sqlString
而不是使用SYS_REFCURSOR
参数的过程来简化OUT
。所以它可能看起来像"{call BEGIN ? := MY_FUNC(); END}"
甚至"{? = call MY_FUNC()}"
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。谢谢你的提问。