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

org.firebirdsql.gds.ng.IConnectionProperties 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.DatabaseParameterBuffer;

/**
 * Connection properties for the Firebird connection.
 * 

* TODO Remove overlap/duplication with {@link org.firebirdsql.jdbc.FirebirdConnectionProperties} *

* * @author Mark Rotteveel * @since 3.0 */ public interface IConnectionProperties extends IAttachProperties { /** * Value for {@code sessionTimeZone} that indicates the session time zone should not be set and use server default. */ String SESSION_TIME_ZONE_SERVER = "server"; short DEFAULT_DIALECT = 3; int DEFAULT_BUFFERS_NUMBER = 0; /** * @return Name or alias of the database */ String getDatabaseName(); /** * @param databaseName * Name or alias of the database */ void setDatabaseName(String databaseName); /** * Get the dialect of the client connection *

* NOTE: Implementer should take care to return {@link IConnectionProperties#DEFAULT_DIALECT} if * the value hasn't been set yet. *

* * @return SQL dialect of the client. */ short getConnectionDialect(); /** * Set the dialect of the client connection *

* NOTE: Implementer should take care to use {@link #DEFAULT_DIALECT} if the * value hasn't been set yet. *

* * @param connectionDialect * SQL dialect of the client. */ void setConnectionDialect(short connectionDialect); /** * Get the page cache size. *

* A value of 0 indicates that the value is not set, and that * the server default is used. *

*

* This option is only relevant for Firebird implementations with per connection cache (eg Classic) *

*

* NOTE: Implementer should take care to return {@link IConnectionProperties#DEFAULT_BUFFERS_NUMBER} if * the value hasn't been set yet. *

* * @return number of cache buffers that should be allocated for this * connection, should be specified for ClassicServer instances, * SuperServer has a server-wide configuration parameter. */ int getPageCacheSize(); /** * Set the page cache size. *

* A value of 0 indicates that the value is not set, and that * the server default is used. *

*

* This option is only relevant for Firebird implementations with per connection cache (eg Classic) *

*

* NOTE: Implementer should take care to use {@link #DEFAULT_BUFFERS_NUMBER} if * the value hasn't been set yet. *

* * @param pageCacheSize * number of cache buffers that should be allocated for this * connection, should be specified for ClassicServer instances, * SuperServer has a server-wide configuration parameter. */ void setPageCacheSize(int pageCacheSize); /** * Set if {@link java.sql.ResultSet} should be {@link java.sql.ResultSet#HOLD_CURSORS_OVER_COMMIT} by default. * * @param holdable * true ResultSets are holdable, false (default) ResultSets are {@link * java.sql.ResultSet#CLOSE_CURSORS_AT_COMMIT} */ void setResultSetDefaultHoldable(boolean holdable); /** * Get whether ResultSets are holdable by default. * * @return true ResultSets by default are {@link java.sql.ResultSet#HOLD_CURSORS_OVER_COMMIT}, * false (default), ResultSets * are {@link java.sql.ResultSet#CLOSE_CURSORS_AT_COMMIT} */ boolean isResultSetDefaultHoldable(); /** * Set if {@link java.sql.ResultSetMetaData#getColumnName(int)} returns the columnLabel instead of the * columnName. *

* The default behaviour (with columnLabelForName=false is JDBC-compliant. The behavior for value * true is * to provide compatibility with tools with a wrong expectation. *

* * @param columnLabelForName * false JDBC compliant behavior (columnName is returned), true * compatibility option (columnLabel is returned) */ void setColumnLabelForName(boolean columnLabelForName); /** * Gets the current setting of columnLabelForName * * @return false JDBC compliant behavior (columnName is returned), true * compatibility option (columnLabel is returned) * @see #setColumnLabelForName(boolean) */ boolean isColumnLabelForName(); /** * Sets the {@code sessionTimeZone}. * * @param sessionTimeZone * Firebird 4+ session time zone name (we strongly suggest to use Java compatible names only), * use {@code "server"} to use server default time zone (note: conversion will use JVM default time zone) * @since 4.0 */ void setSessionTimeZone(String sessionTimeZone); /** * Get the {@code sessionTimeZone}. * * @return value for {@code sessionTimeZone} * @since 4.0 */ String getSessionTimeZone(); /** * Gets the extra database parameters. This can be used to pass extra database parameters that are not directly * supported. *

* An immutable instance of IConnectionProperties must return a copy. *

* * @return DatabaseParameterBuffer instance. */ DatabaseParameterBuffer getExtraDatabaseParameters(); /** * @return An immutable version of this instance as an implementation of {@link IConnectionProperties} */ @Override IConnectionProperties asImmutable(); /** * @return A new, mutable, instance as an implementation of {@link IConnectionProperties} with all properties * copied. */ @Override IConnectionProperties asNewMutable(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy