Что является эквивалентом Oracle REF CURSOR в Postgresql при использовании JDBC?
-
01-07-2019 - |
Вопрос
В Oracle я могу объявить ссылочный курсор...
TYPE t_spool IS REF CURSOR RETURN spool%ROWTYPE;
... и используйте его для передачи курсора в качестве возвращаемого значения...
FUNCTION end_spool
RETURN t_spool
AS
v_spool t_spool;
BEGIN
COMMIT;
OPEN v_spool FOR
SELECT
*
FROM
spool
WHERE
key = g_spool_key
ORDER BY
seq;
RETURN v_spool;
END end_spool;
...а затем захватить его как набор результатов с помощью JDBC...
private Connection conn;
private CallableStatement stmt;
private OracleResultSet rset;
[...clip...]
stmt = conn.prepareCall("{ ? = call " + call + "}");
stmt.registerOutParameter(1, OracleTypes.CURSOR);
stmt.execute();
rset = (OracleResultSet)stmt.getObject(1);
Что такое эквивалент в Postgresql?
Решение
Возможно, это поможет: http://jdbc.postgresql.org/documentation/83/callproc.html#callproc-resultset-setof
Раньше я с этим особо не заморачивался :P
Не связан с StackOverflow