Java:使用引用游标作为 OUT 调用存储过程时结果集为空

标签 java oracle plsql cursor resultset

我尝试从 Java 调用 StoredProcedure,但返回的结果始终为 false。实际上,它必须返回 100 条记录。连接建立良好。

我有一个存储过程

 PROCEDURE get_records
   (
      grp1     IN a.name%TYPE DEFAULT NULL
     ,grp2 IN a.name%TYPE DEFAULT NULL
     ,grp3        IN a.name%TYPE DEFAULT NULL
     ,grp4          IN a.name%TYPE DEFAULT NULL
     ,grp5               IN a.name%TYPE DEFAULT NULL
     ,flag1     IN a.flag%TYPE DEFAULT 'F'
     ,flag2       IN a.flag%TYPE DEFAULT 'F'
     ,refercursor_out          OUT SYS_REFCURSOR
   );

我的java程序:

import java.io.IOException;
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;

import oracle.jdbc.driver.OracleTypes;

class DAO1 {
    public static void main(String args[]) throws SQLException, IOException {
        // Load the driver
        DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
        Connection conn = DriverManager
                .getConnection("jdbc:oracle:thin:admin/admin@//host1:1521/abcdev");
        System.out.println(conn);

        // Prepare to call the stored procedure get_group_details.
        CallableStatement cstmt = conn
                .prepareCall("{call mypackage.get_records (?,?,?,?,?,?,?,?)}");

        cstmt.registerOutParameter(8, OracleTypes.CURSOR); // REF CURSOR

        cstmt.setString(1, "");
        cstmt.setString(2, "");
        cstmt.setString(3, "");
        cstmt.setString(4, "");
        cstmt.setString(5, "");
        cstmt.setString(6, "");
        cstmt.setString(7, "");

        // execute get_records
        //cstmt.execute(); //updated
        cstmt.executeQuery(); //updated

        ResultSet rs0 = (ResultSet) cstmt.getObject(8);
        System.out.println("rs0 is " + rs0.next());

        /*
         * ResultSet rs = ((OracleCallableStatement) cstmt).getCursor(8);
         * System.out.println("rs is " + rs.next());
         * 
         * while (rs.next()) { System.out.println(".."); }
         */
        // Close the statement
        cstmt.close();
        // Close the connection
        conn.close();
    }
}

当前输出:

oracle.jdbc.driver.OracleConnection@5afec107
rs0 is false

问题 - 为什么它是假的?我预计结果集中有 100 条记录。有记录,并且在sql Developer执行测试脚本时可见。

begin
 mypackage.get_records(refercursor_out => :refercursor_out);
end;
// this returns 100's of records

更新:08/08

我没有获取数据的原因不是代码问题,当我将一些值传递给第6个参数时,它正在返回数据。因此关闭线程;将 @Klas Lindbäck 的答案标记为建议正确执行方法的答案。 [尽管在本例中execute()、executeQuery() 和executeUpdate() 返回结果集中的数据]

最佳答案

您没有使用正确的语义。 execute 具有与 executeQuery 不同的语义。

The execute method returns a boolean to indicate the form of the first result. You must call either the method getResultSet or getUpdateCount to retrieve the result; you must call getMoreResults to move to any subsequent result(s).

最简单的解决方案(最小的代码更改)是切换到 executeQuery:

    // execute get_records
    cstmt.executeQuery();

关于Java:使用引用游标作为 OUT 调用存储过程时结果集为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25190219/

相关文章:

java - Java文件中如何指定相对文件路径,使其放入jar文件后仍能正常工作?

java - 运行一次迭代后,循环移动到代码中的错误位置

sql - oracle中的子选择

sql - 根据列的最大值选择行

java.sql.SQLException : Invalid argument(s) in call: Use setNull for user-defined types and REF types

sql - 如何创建pl sql函数以检查数据库中是否存在数据

java - 将java日期转换为json日期

java - 具有使用 Swing 输入的文本字段的 GUI

java - 找不到 OffLine WLST 类

oracle - 执行立即语句时无效的 ALTER TABLE 选项