All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.snowflake.client.jdbc.SnowflakeResultSet Maven / Gradle / Ivy

There is a newer version: 3.20.0
Show newest version
/*
 * Copyright (c) 2012-2019 Snowflake Computing Inc. All rights reserved.
 */

package net.snowflake.client.jdbc;

import java.sql.SQLException;
import java.util.List;
import net.snowflake.client.core.QueryStatus;

/** This interface defines Snowflake specific APIs for ResultSet */
public interface SnowflakeResultSet {
  /**
   * @return the Snowflake query ID of the query which generated this result set
   * @throws SQLException if an error is encountered
   */
  String getQueryID() throws SQLException;

  /**
   * This function retrieves the status of an asynchronous query. An empty ResultSet object has
   * already been returned but the query may still be running. This function can be used to poll to
   * see if it is possible to retrieve results from the ResultSet yet. See
   * Client/src/main/java/net/snowflake/client/core/QueryStatus.java for the list of all possible
   * query statuses. QueryStatus = SUCCESS means results can be retrieved.
   *
   * @return QueryStatus enum showing status of query
   * @throws SQLException if an error is encountered
   */
  QueryStatus getStatus() throws SQLException;

  /**
   * This function retrieves the error message recorded from the error status of an asynchronous
   * query. If there is no error or no error is returned by the server, an empty string will be
   * returned.
   *
   * @return String value of query's error message
   * @throws SQLException if an error is encountered
   */
  String getQueryErrorMessage() throws SQLException;

  /**
   * This function retrieves the status of an asynchronous query. An empty ResultSet object has
   * already been returned, but the query may still be running. This function can be used to query
   * whether it is possible to retrieve results from the ResultSet already.
   *
   * 

status.isSuccess() means that results can be retrieved. * * @return an instance containing query metadata * @throws SQLException if an error is encountered */ QueryStatusV2 getStatusV2() throws SQLException; /** * Get a list of ResultSetSerializables for the ResultSet in order to parallel processing * * @param maxSizeInBytes The expected max data size wrapped in the ResultSetSerializables object. * NOTE: this parameter is intended to make the data size in each serializable object to be * less than it. But if user specifies a small value which may be smaller than the data size * of one result chunk. So the definition can't be guaranteed completely. For this special * case, one serializable object is used to wrap the data chunk. * @return a list of ResultSetSerializables * @throws SQLException if fails to get the ResultSetSerializable objects. */ List getResultSetSerializables(long maxSizeInBytes) throws SQLException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy