java - 使用 JDBC 获取多个结果集不起作用

标签 java sql-server hibernate jdbc

<分区>

我应该从第三方 SQL Server 数据库调用存储过程(具有只读权限)。 此外,当我尝试在 DataGrip 中执行此过程时:

EXEC Web.example_procedure 2、3、4

我收到了两个结果:

先:

<anonymous>
-----------
3

第二个:

column_1 | column_2
------------------
   k1    |   v1
   k2    |   v2
   k3    |   v3
...

我需要第二张 table 。

由于这个 article,现在我正在做下一步

private static void executeStatement(Connection con) {
    try {
        String SQL = "EXEC Web.example_procedure 2, 3, 4";
        Statement stmt = con.createStatement();
        boolean results = stmt.execute(SQL);
        int rsCount = 0;

        //Loop through the available result sets.
        do {
            if (results) {
                ResultSet rs = stmt.getResultSet();
                rsCount++;

                //Show data from the result set.
                System.out.println("RESULT SET #" + rsCount);
                while (rs.next()) {
                    // something will be here
                }
                rs.close();
            }
            results = stmt.getMoreResults();
        } while (results);
        stmt.close();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

输出是:

结果集#1

换句话说,我只得到第一个结果。 如何获取第二个表?

  • 我可以修改 SQL 查询吗? (这将只返回一张没有 第一个整数结果)
  • JDBC?
  • hibernate ?

我会很高兴任何工作变体。

更新

感谢@MarkRotteveel 和他的 answer - 我解决了问题

String sql = "EXEC Web.example_procedure 2, 3, 4";
PreparedStatement stmt = con.prepareStatement(sql);

boolean result = stmt.execute();

while (true) {
    if (result) {
        ResultSet rs = stmt.getResultSet();

        // in my case first table has only one column, 
        // and I need the second table, which has 9 columns
        if (rs.getMetaData().getColumnCount() > 1) {

            // go through the rows
            while (rs.next()) {

                // for example what we can do
                rs.getMetaData().getColumnCount(); // return column count in the current result set
                rs.getObject(int columnIndex); // get value for column index. Must be not greater than .getColumnCount()
            }
        }

    } else {
        int updateCount = stmt.getUpdateCount();
        if (updateCount == -1) {
            // no more results
            break;
        }
    }
    result = stmt.getMoreResults();
}

最佳答案

使用 JDBC CallableStatement:

cstmt.registerOutParameter()
cstmt.getObject()

  String sql = "{call getEmpName (?, ?)}";
  cstmt = conn.prepareCall(sql);

  //Bind IN parameter first, then bind OUT parameter
  int empID = 102;
  cstmt.setInt(1, empID); // This would set ID as 102
  // Because second parameter is OUT so register it
  cstmt.registerOutParameter(2, OracleTypes.CURSOR);

  //Use execute method to run stored procedure.
  System.out.println("Executing stored procedure..." );
  cstmt.execute();

  //Retrieve data
  rs = (ResultSet) cstmt.getObject(1);

https://docs.oracle.com/cd/E17952_01/connector-j-en/connector-j-usagenotes-statements-callable.html

关于java - 使用 JDBC 获取多个结果集不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44516403/

相关文章:

java - .jar 文件中的图标路径

java - Prettyfaces 和基于容器的安全性

sql - 设置AVG结果AS列

SQL : Rebase number to 100

sql - 在 SQL 中获取该月的最后一天

java - 在没有第三方库的情况下下载远程图像的最佳方法?

java - 我可以通过编程方式检测当前 WiFi 网络上是否有任何 Chromecast 设备吗?

java - 从端点调用时,Spring Boot 获取 UTC+1 而不是 GMT

java - Hibernate:未知的mappedBy in:,引用的属性未知:

hibernate - @Temporal(TemporalType.DATE) 的问题