使用 Microsoft JDBC Driver for SQL Server 时,可能必须处理复杂语句,其中包括运行时动态生成的语句。 复杂语句通常执行各种不同的任务,包括更新、插入和删除。 这类语句可能还会返回多个结果集和输出参数。 在这些情况下,运行该语句的 Java 代码预先可能不知道返回的对象和数据的类型和数目。
为了处理复杂语句,JDBC 驱动程序提供多种方法查询返回的对象和数据,以便应用程序可正确处理这些内容。 处理复杂语句的关键在于 SQLServerStatement 类的 execute 方法。 此方法将返回布尔值。 当该值为 true 时,从该语句返回的第一个结果为结果集。 如果该值为 false,则返回的第一个结果为更新计数。
知道返回的对象或数据的类型后,可以使用 getResultSet 或 getUpdateCount 方法处理这些数据。 要继续处理从复杂语句返回的下一个对象或数据,可以调用 getMoreResults 方法。
在下面的示例中,将向此函数传递 AdventureWorks2022 示例数据库的开放式连接,构造一条组合了存储过程调用和 SQL 语句的复杂语句,再运行这些语句,然后使用 do 循环处理返回的所有结果集和更新计数。
public static void executeComplexStatement(Connection con) {
    try (Statement stmt = con.createStatement();) {
        String sqlStringWithUnknownResults = "{call dbo.uspGetEmployeeManagers(50)}; SELECT TOP 10 * FROM Person.Contact";
        boolean results = stmt.execute(sqlStringWithUnknownResults);
        int count = 0;
        do {
            if (results) {
                ResultSet rs = stmt.getResultSet();
                System.out.println("Result set data displayed here.");
            }
            else {
                count = stmt.getUpdateCount();
                if (count >= 0) {
                    System.out.println("DDL or update data displayed here.");
                }
                else {
                    System.out.println("No more results to process.");
                }
            }
            results = stmt.getMoreResults();
        }
        while (results || count != -1);
    }
    // Handle any errors that may have occurred.
    catch (SQLException e) {
        e.printStackTrace();
    }
}