Interface FirebirdStatement

All Superinterfaces:
AutoCloseable, Statement, Wrapper
All Known Subinterfaces:
FirebirdCallableStatement, FirebirdPreparedStatement
All Known Implementing Classes:
AbstractStatement, FBCallableStatement, FBPreparedStatement, FBStatement

@NullMarked public interface FirebirdStatement extends Statement
Firebird-specific extensions to the Statement interface.
Author:
Roman Rokytskyy
  • Method Details

    • getInsertedRowsCount

      int getInsertedRowsCount() throws SQLException
      Get number of inserted rows. You can call this method multiple times, it does not affect the JDBC result number.
      Returns:
      number of inserted rows or -1 if current result is result set.
      Throws:
      SQLException - if database error occurs.
    • getUpdatedRowsCount

      int getUpdatedRowsCount() throws SQLException
      Get number of updated rows. You can call this method multiple times, it does not affect the JDBC result number.
      Returns:
      number of updated rows or -1 if current result is result set.
      Throws:
      SQLException - if database error occurs.
    • getDeletedRowsCount

      int getDeletedRowsCount() throws SQLException
      Get number of deleted rows. You can call this method multiple times, it does not affect the JDBC result number.
      Returns:
      number of deleted rows or -1 if current result is result set.
      Throws:
      SQLException - if database error occurs.
    • hasOpenResultSet

      boolean hasOpenResultSet()
      Check if this statement has open result set. Note, this method works correctly if auto-commit is disabled. In auto-commit mode it will always return false because from the statement's point of view result set is not open (in auto-commit mode complete result set is fetched and cached in wrapping object before returning from the Statement.getResultSet() method).
      Returns:
      true if there's already open result set associated with this statement, otherwise false.
    • getCurrentResultSet

      @Deprecated(since="6", forRemoval=true) @Nullable ResultSet getCurrentResultSet() throws SQLException
      Deprecated, for removal: This API element is subject to removal in a future version.
      Use Statement.getResultSet() instead, will be removed in Jaybird 7
      Get current result set. Behaviour of this method is similar to the behavior of the Statement.getResultSet().
      Returns:
      instance of ResultSet representing current result set or null if it is not available.
      Throws:
      SQLException - if a database access error happens
    • isValid

      boolean isValid()
      Check if this statement is valid.
      Returns:
      true if statement is valid and can be used to execute SQL.
    • getLastExecutionPlan

      @Deprecated(since="6", forRemoval=false) default @Nullable String getLastExecutionPlan() throws SQLException
      Deprecated.
      use getExecutionPlan(); there are currently no plans to remove this method
      Throws:
      SQLException
    • getExecutionPlan

      @Nullable String getExecutionPlan() throws SQLException
      Gets the simple execution plan of the statement.

      Behaviour depends on the specific type:

      Returns:
      execution plan returned by the server
      Throws:
      SQLException - if no statement was executed or prepared before calling this method, if the statement is not valid or open, or there was an error when obtaining the execution plan
      Since:
      6
      See Also:
    • getLastExplainedExecutionPlan

      @Deprecated(since="6", forRemoval=false) default @Nullable String getLastExplainedExecutionPlan() throws SQLException
      Deprecated.
      use getExplainedExecutionPlan(); there are currently no plans to remove this method
      Throws:
      SQLException
      See Also:
    • getExplainedExecutionPlan

      @Nullable String getExplainedExecutionPlan() throws SQLException
      Gets the explained (or detailed) execution plan of the statement.

      The explained execution plan is a more structured and comprehensible form compared to the (simple) execution plan returned by getExecutionPlan(). This requires Firebird 3.0 or higher.

      Behaviour depends on the specific type:

      Returns:
      execution plan returned by the server
      Throws:
      SQLException - if no statement was executed or prepared before calling this method, if the statement is not valid or open, or there was an error when obtaining the execution plan
      Since:
      6
      See Also:
    • getLocalStatementId

      @InternalApi int getLocalStatementId()
      The local statement id is intended to identify the statement for internal implementation purposes.

      NOTE: This method is only included in this interface to try and avoid problems with proxied and bytecode enhanced classes in certain libraries, you should normally have no reason to call this method directly.

      The id is expected - but not guaranteed - to be unique for a single connection, and - preferably - for the entire JVM run time as well.

      Returns:
      The local statement id.