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

org.firebirdsql.gds.ng.FbStatement Maven / Gradle / Ivy

There is a newer version: 6.0.0-beta-1
Show newest version
/*
 * Public Firebird Java API.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *    1. Redistributions of source code must retain the above copyright notice,
 *       this list of conditions and the following disclaimer.
 *    2. Redistributions in binary form must reproduce the above copyright
 *       notice, this list of conditions and the following disclaimer in the
 *       documentation and/or other materials provided with the distribution.
 *    3. The name of the author may not be used to endorse or promote products
 *       derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package org.firebirdsql.gds.ng;

import org.firebirdsql.gds.ng.fields.RowDescriptor;
import org.firebirdsql.gds.ng.fields.RowValue;
import org.firebirdsql.gds.ng.listeners.ExceptionListenable;
import org.firebirdsql.gds.ng.listeners.StatementListener;

import java.sql.SQLException;

/**
 * API for statement handles.
 * 

* All methods defined in this interface are required to notify all {@code SQLException} thrown from the methods * defined in this interface. *

* * @author Mark Rotteveel * @since 3.0 */ public interface FbStatement extends ExceptionListenable { /** * @return Transaction currently associated with this statement */ FbTransaction getTransaction(); /** * @return The database connection that created this statement */ FbDatabase getDatabase(); /** * Associates a transaction with this statement * * @param transaction * The transaction * @throws SQLException */ void setTransaction(FbTransaction transaction) throws SQLException; /** * @return descriptor of the parameters of this statement */ RowDescriptor getParameterDescriptor(); /** * @return descriptor of the fields returned by this statement * @deprecated Use {@link #getRowDescriptor()} instead; will be removed in Jaybird 5 */ @Deprecated RowDescriptor getFieldDescriptor(); /** * @return descriptor of the row returned by this statement */ RowDescriptor getRowDescriptor(); /** * @return The statement type */ StatementType getType(); /** * @return The current state of this statement */ StatementState getState(); /** * @return The Firebird statement handle identifier */ int getHandle(); /** * Close and deallocate this statement. * * @throws SQLException */ void close() throws SQLException; /** * Closes the cursor associated with this statement, leaving the * statement itself allocated. *

* Equivalent to calling {@link #closeCursor(boolean)} with {@code false}. *

* * @throws SQLException */ void closeCursor() throws SQLException; /** * Closes the cursor associated with this statement, leaving the statement itself allocated. *

* When this method is called in preparation of a commit or rollback (see {@code transactionEnd}), then * implementations may opt to not close the cursor on the server if the server closes the cursor automatically. *

* * @param transactionEnd * Close is in response to a transaction end. * @throws SQLException */ void closeCursor(boolean transactionEnd) throws SQLException; /** * Prepare the statement text. *

* If this handle is in state {@link StatementState#NEW} then it will first allocate the statement. *

* * @param statementText * Statement text * @throws SQLException * If a database access error occurs, or this statement is currently executing a query. */ void prepare(String statementText) throws SQLException; /** * Validates if the number of parameters matches the expected number and types, and if all values have been set. * * @param parameters * Parameter values to validate * @throws SQLException * When the number or type of parameters does not match {@link #getParameterDescriptor()}, or when a * parameter has not been set. */ void validateParameters(final RowValue parameters) throws SQLException; /** * Execute the statement. * * @param parameters * The list of parameter values to use for execution. * @throws SQLException * When the number of type of parameters does not match the types returned by {@link #getParameterDescriptor()}, * a parameter value was not set, or when an error occurred executing this statement. */ void execute(RowValue parameters) throws SQLException; /** * Requests this statement to fetch the next fetchSize rows. *

* Fetched rows are not returned from this method, but sent to the registered {@link org.firebirdsql.gds.ng.listeners.StatementListener} instances. *

* * @param fetchSize * Number of rows to fetch (must be > 0) * @throws SQLException * For database access errors, when called on a closed statement, when no cursor is open or when the fetch * size is not > 0. */ void fetchRows(int fetchSize) throws SQLException; /** * Registers a {@link org.firebirdsql.gds.ng.listeners.StatementListener}. * * @param statementListener * The row listener */ void addStatementListener(StatementListener statementListener); /** * Removes a {@link org.firebirdsql.gds.ng.listeners.StatementListener}. * * @param statementListener * The row listener */ void removeStatementListener(StatementListener statementListener); /** * Request statement info. * * @param requestItems * Array of info items to request * @param bufferLength * Response buffer length to use * @param infoProcessor * Implementation of {@link InfoProcessor} to transform * the info response * @return Transformed info response of type T * @throws SQLException * For errors retrieving or transforming the response. */ T getSqlInfo(byte[] requestItems, int bufferLength, InfoProcessor infoProcessor) throws SQLException; /** * Request statement info. * * @param requestItems * Array of info items to request * @param bufferLength * Response buffer length to use * @return Response buffer * @throws SQLException */ byte[] getSqlInfo(byte[] requestItems, int bufferLength) throws SQLException; /** * @return The default size to use for the sql info buffer */ int getDefaultSqlInfoSize(); /** * @return The maximum size to use for the sql info buffer */ int getMaxSqlInfoSize(); /** * @return The execution plan of the currently prepared statement * @throws SQLException * If this statement is closed. */ String getExecutionPlan() throws SQLException; /** * @return The detailed execution plan of the currently prepared statement * @throws SQLException * If this statement is closed. */ String getExplainedExecutionPlan() throws SQLException; /** * Retrieves the SQL counts for the last execution of this statement. *

* The retrieved SQL counts are also notified to all registered {@link StatementListener}s. *

*

* In general the {@link FbStatement} will (should) retrieve and notify listeners of the SQL counts automatically at times were * it is relevant (eg after executing a statement that does not produce multiple rows, or after fetching all rows). *

* * @return The SQL counts of the last execution of this statement * @throws SQLException * If this statement is closed, or if this statement is in state {@link StatementState#CURSOR_OPEN} and not * all rows have been fetched. */ SqlCountHolder getSqlCounts() throws SQLException; /** * Sets the named cursor name for this statement. * * @param cursorName * Name of the cursor * @throws SQLException * If this statement is closed, TODO: Other reasons (eg cursor open)? */ void setCursorName(String cursorName) throws SQLException; /** * @return A potentially cached empty row descriptor for this statement or database. */ RowDescriptor emptyRowDescriptor(); /** * Ensures that the statement cursor is closed. Resets a statement so it is ready to be reused for re-execute or * prepare. *

* Implementations should only close an open cursor and log this fact with a stacktrace on debug. This is a stopgap * measure for situations where the code using this statement handle has not been able to properly close the * cursor. *

* * @param transactionEnd * Close is in response to a transaction end * @throws SQLException * If this statement is closed or the cursor could not be closed. * @since 3.0.6 */ void ensureClosedCursor(boolean transactionEnd) throws SQLException; /** * Sets the statement timeout. *

* The statement timeout value is ignored in implementations that do not support timeouts. If the provided * timeout value is greater than supported (eg greater than ‭4294967295‬ milliseconds on Firebird 4), the * implementation should behave as if zero ({@code 0}) was set, but still report the original value. *

*

* The configured timeout only affects subsequent executes on this statement. The timeout includes time spent * between reading from the result set. *

* * @param timeoutMillis * Timeout value in milliseconds * @throws SQLException * If the value is less than zero, this statement is closed, or a database access error occurs * @since 4.0 */ void setTimeout(long timeoutMillis) throws SQLException; /** * Gets the current statement timeout for this statement. *

* This method will only return the current statement timeout value for this method, it will not consider attachment * or connection level timeouts. This is an implementation decision that might change in a point release. *

* * @return The configured timeout in milliseconds; read the documentation in {@link #setTimeout(long)} * @throws SQLException * If this statement is closed, or a database access error occurs * @see #setTimeout(long) * @since 4.0 */ long getTimeout() throws SQLException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy