/* * Copyright (c) 1996, 2024, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package java.sql; /** * Comprehensive information about the database as a whole. *
* This interface is implemented by driver vendors to let users know the capabilities * of a Database Management System (DBMS) in combination with * the driver based on JDBC technology * ("JDBC driver") that is used with it. Different relational DBMSs often support * different features, implement features in different ways, and use different * data types. In addition, a driver may implement a feature on top of what the * DBMS offers. Information returned by methods in this interface applies * to the capabilities of a particular driver and a particular DBMS working * together. Note that as used in this documentation, the term "database" is * used generically to refer to both the driver and DBMS. *
* A user for this interface is commonly a tool that needs to discover how to * deal with the underlying DBMS. This is especially true for applications * that are intended to be used with more than one DBMS. For example, a tool might use the method * {@code getTypeInfo} to find out what data types can be used in a * {@code CREATE TABLE} statement. Or a user might call the method * {@code supportsCorrelatedSubqueries} to see if it is possible to use * a correlated subquery or {@code supportsBatchUpdates} to see if it is * possible to use batch updates. *
* Some {@code DatabaseMetaData} methods return lists of information * in the form of {@code ResultSet} objects. * Regular {@code ResultSet} methods, such as * {@code getString} and {@code getInt}, can be used * to retrieve the data from these {@code ResultSet} objects. If * a given form of metadata is not available, an empty {@code ResultSet} * will be returned. Additional columns beyond the columns defined to be * returned by the {@code ResultSet} object for a given method * can be defined by the JDBC driver vendor and must be accessed * by their column label. *
* Some {@code DatabaseMetaData} methods take arguments that are * String patterns. These arguments all have names such as fooPattern. * Within a pattern String, "%" means match any substring of 0 or more * characters, and "_" means match any one character. Only metadata * entries matching the search pattern are returned. If a search pattern * argument is set to {@code null}, that argument's criterion will * be dropped from the search. * * @since 1.1 */ public interface DatabaseMetaData extends Wrapper { //---------------------------------------------------------------------- // First, a variety of minor information about the target database. /** * Retrieves whether the current user can call all the procedures * returned by the method {@code getProcedures}. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean allProceduresAreCallable() throws SQLException; /** * Retrieves whether the current user can use all the tables returned * by the method {@code getTables} in a {@code SELECT} * statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean allTablesAreSelectable() throws SQLException; /** * Retrieves the URL for this DBMS. * * @return the URL for this DBMS or {@code null} if it cannot be * generated * @throws SQLException if a database access error occurs */ String getURL() throws SQLException; /** * Retrieves the user name as known to this database. * * @return the database user name * @throws SQLException if a database access error occurs */ String getUserName() throws SQLException; /** * Retrieves whether this database is in read-only mode. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean isReadOnly() throws SQLException; /** * Retrieves whether {@code NULL} values are sorted high. * Sorted high means that {@code NULL} values * sort higher than any other value in a domain. In an ascending order, * if this method returns {@code true}, {@code NULL} values * will appear at the end. By contrast, the method * {@code nullsAreSortedAtEnd} indicates whether {@code NULL} values * are sorted at the end regardless of sort order. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean nullsAreSortedHigh() throws SQLException; /** * Retrieves whether {@code NULL} values are sorted low. * Sorted low means that {@code NULL} values * sort lower than any other value in a domain. In an ascending order, * if this method returns {@code true}, {@code NULL} values * will appear at the beginning. By contrast, the method * {@code nullsAreSortedAtStart} indicates whether {@code NULL} values * are sorted at the beginning regardless of sort order. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean nullsAreSortedLow() throws SQLException; /** * Retrieves whether {@code NULL} values are sorted at the start regardless * of sort order. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean nullsAreSortedAtStart() throws SQLException; /** * Retrieves whether {@code NULL} values are sorted at the end regardless of * sort order. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean nullsAreSortedAtEnd() throws SQLException; /** * Retrieves the name of this database product. * * @return database product name * @throws SQLException if a database access error occurs */ String getDatabaseProductName() throws SQLException; /** * Retrieves the version number of this database product. * * @return database version number * @throws SQLException if a database access error occurs */ String getDatabaseProductVersion() throws SQLException; /** * Retrieves the name of this JDBC driver. * * @return JDBC driver name * @throws SQLException if a database access error occurs */ String getDriverName() throws SQLException; /** * Retrieves the version number of this JDBC driver as a {@code String}. * * @return JDBC driver version * @throws SQLException if a database access error occurs */ String getDriverVersion() throws SQLException; /** * Retrieves this JDBC driver's major version number. * * @return JDBC driver major version */ int getDriverMajorVersion(); /** * Retrieves this JDBC driver's minor version number. * * @return JDBC driver minor version number */ int getDriverMinorVersion(); /** * Retrieves whether this database stores tables in a local file. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean usesLocalFiles() throws SQLException; /** * Retrieves whether this database uses a file for each table. * * @return {@code true} if this database uses a local file for each table; * {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean usesLocalFilePerTable() throws SQLException; /** * Retrieves whether this database treats mixed case unquoted SQL identifiers as * case sensitive and as a result stores them in mixed case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsMixedCaseIdentifiers() throws SQLException; /** * Retrieves whether this database treats mixed case unquoted SQL identifiers as * case insensitive and stores them in upper case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean storesUpperCaseIdentifiers() throws SQLException; /** * Retrieves whether this database treats mixed case unquoted SQL identifiers as * case insensitive and stores them in lower case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean storesLowerCaseIdentifiers() throws SQLException; /** * Retrieves whether this database treats mixed case unquoted SQL identifiers as * case insensitive and stores them in mixed case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean storesMixedCaseIdentifiers() throws SQLException; /** * Retrieves whether this database treats mixed case quoted SQL identifiers as * case sensitive and as a result stores them in mixed case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsMixedCaseQuotedIdentifiers() throws SQLException; /** * Retrieves whether this database treats mixed case quoted SQL identifiers as * case insensitive and stores them in upper case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean storesUpperCaseQuotedIdentifiers() throws SQLException; /** * Retrieves whether this database treats mixed case quoted SQL identifiers as * case insensitive and stores them in lower case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean storesLowerCaseQuotedIdentifiers() throws SQLException; /** * Retrieves whether this database treats mixed case quoted SQL identifiers as * case insensitive and stores them in mixed case. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean storesMixedCaseQuotedIdentifiers() throws SQLException; /** * Retrieves the string used to quote SQL identifiers. * This method returns a space " " if identifier quoting is not supported. * * @return the quoting string or a space if quoting is not supported * @throws SQLException if a database access error occurs */ String getIdentifierQuoteString() throws SQLException; /** * Retrieves a comma-separated list of all of this database's SQL keywords * that are NOT also SQL:2003 keywords. * * @return the list of this database's keywords that are not also * SQL:2003 keywords * @throws SQLException if a database access error occurs */ String getSQLKeywords() throws SQLException; /** * Retrieves a comma-separated list of math functions available with * this database. These are the Open /Open CLI math function names used in * the JDBC function escape clause. * * @return the list of math functions supported by this database * @throws SQLException if a database access error occurs */ String getNumericFunctions() throws SQLException; /** * Retrieves a comma-separated list of string functions available with * this database. These are the Open Group CLI string function names used * in the JDBC function escape clause. * * @return the list of string functions supported by this database * @throws SQLException if a database access error occurs */ String getStringFunctions() throws SQLException; /** * Retrieves a comma-separated list of system functions available with * this database. These are the Open Group CLI system function names used * in the JDBC function escape clause. * * @return a list of system functions supported by this database * @throws SQLException if a database access error occurs */ String getSystemFunctions() throws SQLException; /** * Retrieves a comma-separated list of the time and date functions available * with this database. * * @return the list of time and date functions supported by this database * @throws SQLException if a database access error occurs */ String getTimeDateFunctions() throws SQLException; /** * Retrieves the string that can be used to escape wildcard characters. * This is the string that can be used to escape '_' or '%' in * the catalog search parameters that are a pattern (and therefore use one * of the wildcard characters). * *
The '_' character represents any single character; * the '%' character represents any sequence of zero or * more characters. * * @return the string used to escape wildcard characters * @throws SQLException if a database access error occurs */ String getSearchStringEscape() throws SQLException; /** * Retrieves all the "extra" characters that can be used in unquoted * identifier names (those beyond a-z, A-Z, 0-9 and _). * * @return the string containing the extra characters * @throws SQLException if a database access error occurs */ String getExtraNameCharacters() throws SQLException; //-------------------------------------------------------------------- // Functions describing which features are supported. /** * Retrieves whether this database supports {@code ALTER TABLE} * with add column. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsAlterTableWithAddColumn() throws SQLException; /** * Retrieves whether this database supports {@code ALTER TABLE} * with drop column. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsAlterTableWithDropColumn() throws SQLException; /** * Retrieves whether this database supports column aliasing. * *
If so, the SQL AS clause can be used to provide names for * computed columns or to provide alias names for columns as * required. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsColumnAliasing() throws SQLException; /** * Retrieves whether this database supports concatenations between * {@code NULL} and non-{@code NULL} values being * {@code NULL}. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean nullPlusNonNullIsNull() throws SQLException; /** * Retrieves whether this database supports the JDBC scalar function * {@code CONVERT} for the conversion of one JDBC type to another. * The JDBC types are the generic SQL data types defined * in {@code java.sql.Types}. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsConvert() throws SQLException; /** * Retrieves whether this database supports the JDBC scalar function * {@code CONVERT} for conversions between the JDBC types fromType * and toType. The JDBC types are the generic SQL data types defined * in {@code java.sql.Types}. * * @param fromType the type to convert from; one of the type codes from * the class {@code java.sql.Types} * @param toType the type to convert to; one of the type codes from * the class {@code java.sql.Types} * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs * @see Types */ boolean supportsConvert(int fromType, int toType) throws SQLException; /** * Retrieves whether this database supports table correlation names. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsTableCorrelationNames() throws SQLException; /** * Retrieves whether, when table correlation names are supported, they * are restricted to being different from the names of the tables. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsDifferentTableCorrelationNames() throws SQLException; /** * Retrieves whether this database supports expressions in * {@code ORDER BY} lists. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsExpressionsInOrderBy() throws SQLException; /** * Retrieves whether this database supports using a column that is * not in the {@code SELECT} statement in an * {@code ORDER BY} clause. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsOrderByUnrelated() throws SQLException; /** * Retrieves whether this database supports some form of * {@code GROUP BY} clause. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsGroupBy() throws SQLException; /** * Retrieves whether this database supports using a column that is * not in the {@code SELECT} statement in a * {@code GROUP BY} clause. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsGroupByUnrelated() throws SQLException; /** * Retrieves whether this database supports using columns not included in * the {@code SELECT} statement in a {@code GROUP BY} clause * provided that all of the columns in the {@code SELECT} statement * are included in the {@code GROUP BY} clause. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsGroupByBeyondSelect() throws SQLException; /** * Retrieves whether this database supports specifying a * {@code LIKE} escape clause. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsLikeEscapeClause() throws SQLException; /** * Retrieves whether this database supports getting multiple * {@code ResultSet} objects from a single call to the * method {@code execute}. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsMultipleResultSets() throws SQLException; /** * Retrieves whether this database allows having multiple * transactions open at once (on different connections). * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsMultipleTransactions() throws SQLException; /** * Retrieves whether columns in this database may be defined as non-nullable. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsNonNullableColumns() throws SQLException; /** * Retrieves whether this database supports the ODBC Minimum SQL grammar. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsMinimumSQLGrammar() throws SQLException; /** * Retrieves whether this database supports the ODBC Core SQL grammar. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsCoreSQLGrammar() throws SQLException; /** * Retrieves whether this database supports the ODBC Extended SQL grammar. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsExtendedSQLGrammar() throws SQLException; /** * Retrieves whether this database supports the ANSI92 entry level SQL * grammar. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsANSI92EntryLevelSQL() throws SQLException; /** * Retrieves whether this database supports the ANSI92 intermediate SQL grammar supported. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsANSI92IntermediateSQL() throws SQLException; /** * Retrieves whether this database supports the ANSI92 full SQL grammar supported. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsANSI92FullSQL() throws SQLException; /** * Retrieves whether this database supports the SQL Integrity * Enhancement Facility. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsIntegrityEnhancementFacility() throws SQLException; /** * Retrieves whether this database supports some form of outer join. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsOuterJoins() throws SQLException; /** * Retrieves whether this database supports full nested outer joins. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsFullOuterJoins() throws SQLException; /** * Retrieves whether this database provides limited support for outer * joins. (This will be {@code true} if the method * {@code supportsFullOuterJoins} returns {@code true}). * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsLimitedOuterJoins() throws SQLException; /** * Retrieves the database vendor's preferred term for "schema". * * @return the vendor term for "schema" * @throws SQLException if a database access error occurs */ String getSchemaTerm() throws SQLException; /** * Retrieves the database vendor's preferred term for "procedure". * * @return the vendor term for "procedure" * @throws SQLException if a database access error occurs */ String getProcedureTerm() throws SQLException; /** * Retrieves the database vendor's preferred term for "catalog". * * @return the vendor term for "catalog" * @throws SQLException if a database access error occurs */ String getCatalogTerm() throws SQLException; /** * Retrieves whether a catalog appears at the start of a fully qualified * table name. If not, the catalog appears at the end. * * @return {@code true} if the catalog name appears at the beginning * of a fully qualified table name; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean isCatalogAtStart() throws SQLException; /** * Retrieves the {@code String} that this database uses as the * separator between a catalog and table name. * * @return the separator string * @throws SQLException if a database access error occurs */ String getCatalogSeparator() throws SQLException; /** * Retrieves whether a schema name can be used in a data manipulation statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSchemasInDataManipulation() throws SQLException; /** * Retrieves whether a schema name can be used in a procedure call statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSchemasInProcedureCalls() throws SQLException; /** * Retrieves whether a schema name can be used in a table definition statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSchemasInTableDefinitions() throws SQLException; /** * Retrieves whether a schema name can be used in an index definition statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSchemasInIndexDefinitions() throws SQLException; /** * Retrieves whether a schema name can be used in a privilege definition statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSchemasInPrivilegeDefinitions() throws SQLException; /** * Retrieves whether a catalog name can be used in a data manipulation statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsCatalogsInDataManipulation() throws SQLException; /** * Retrieves whether a catalog name can be used in a procedure call statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsCatalogsInProcedureCalls() throws SQLException; /** * Retrieves whether a catalog name can be used in a table definition statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsCatalogsInTableDefinitions() throws SQLException; /** * Retrieves whether a catalog name can be used in an index definition statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsCatalogsInIndexDefinitions() throws SQLException; /** * Retrieves whether a catalog name can be used in a privilege definition statement. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsCatalogsInPrivilegeDefinitions() throws SQLException; /** * Retrieves whether this database supports positioned {@code DELETE} * statements. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsPositionedDelete() throws SQLException; /** * Retrieves whether this database supports positioned {@code UPDATE} * statements. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsPositionedUpdate() throws SQLException; /** * Retrieves whether this database supports {@code SELECT FOR UPDATE} * statements. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSelectForUpdate() throws SQLException; /** * Retrieves whether this database supports stored procedure calls * that use the stored procedure escape syntax. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsStoredProcedures() throws SQLException; /** * Retrieves whether this database supports subqueries in comparison * expressions. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSubqueriesInComparisons() throws SQLException; /** * Retrieves whether this database supports subqueries in * {@code EXISTS} expressions. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSubqueriesInExists() throws SQLException; /** * Retrieves whether this database supports subqueries in * {@code IN} expressions. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSubqueriesInIns() throws SQLException; /** * Retrieves whether this database supports subqueries in quantified * expressions. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsSubqueriesInQuantifieds() throws SQLException; /** * Retrieves whether this database supports correlated subqueries. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsCorrelatedSubqueries() throws SQLException; /** * Retrieves whether this database supports SQL {@code UNION}. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsUnion() throws SQLException; /** * Retrieves whether this database supports SQL {@code UNION ALL}. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsUnionAll() throws SQLException; /** * Retrieves whether this database supports keeping cursors open * across commits. * * @return {@code true} if cursors always remain open; * {@code false} if they might not remain open * @throws SQLException if a database access error occurs */ boolean supportsOpenCursorsAcrossCommit() throws SQLException; /** * Retrieves whether this database supports keeping cursors open * across rollbacks. * * @return {@code true} if cursors always remain open; * {@code false} if they might not remain open * @throws SQLException if a database access error occurs */ boolean supportsOpenCursorsAcrossRollback() throws SQLException; /** * Retrieves whether this database supports keeping statements open * across commits. * * @return {@code true} if statements always remain open; * {@code false} if they might not remain open * @throws SQLException if a database access error occurs */ boolean supportsOpenStatementsAcrossCommit() throws SQLException; /** * Retrieves whether this database supports keeping statements open * across rollbacks. * * @return {@code true} if statements always remain open; * {@code false} if they might not remain open * @throws SQLException if a database access error occurs */ boolean supportsOpenStatementsAcrossRollback() throws SQLException; //---------------------------------------------------------------------- // The following group of methods exposes various limitations // based on the target database with the current driver. // Unless otherwise specified, a result of zero means there is no // limit, or the limit is not known. /** * Retrieves the maximum number of hex characters this database allows in an * inline binary literal. * * @return max the maximum length (in hex characters) for a binary literal; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxBinaryLiteralLength() throws SQLException; /** * Retrieves the maximum number of characters this database allows * for a character literal. * * @return the maximum number of characters allowed for a character literal; * a result of zero means that there is no limit or the limit is * not known * @throws SQLException if a database access error occurs */ int getMaxCharLiteralLength() throws SQLException; /** * Retrieves the maximum number of characters this database allows * for a column name. * * @return the maximum number of characters allowed for a column name; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxColumnNameLength() throws SQLException; /** * Retrieves the maximum number of columns this database allows in a * {@code GROUP BY} clause. * * @return the maximum number of columns allowed; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxColumnsInGroupBy() throws SQLException; /** * Retrieves the maximum number of columns this database allows in an index. * * @return the maximum number of columns allowed; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxColumnsInIndex() throws SQLException; /** * Retrieves the maximum number of columns this database allows in an * {@code ORDER BY} clause. * * @return the maximum number of columns allowed; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxColumnsInOrderBy() throws SQLException; /** * Retrieves the maximum number of columns this database allows in a * {@code SELECT} list. * * @return the maximum number of columns allowed; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxColumnsInSelect() throws SQLException; /** * Retrieves the maximum number of columns this database allows in a table. * * @return the maximum number of columns allowed; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxColumnsInTable() throws SQLException; /** * Retrieves the maximum number of concurrent connections to this * database that are possible. * * @return the maximum number of active connections possible at one time; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxConnections() throws SQLException; /** * Retrieves the maximum number of characters that this database allows in a * cursor name. * * @return the maximum number of characters allowed in a cursor name; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxCursorNameLength() throws SQLException; /** * Retrieves the maximum number of bytes this database allows for an * index, including all of the parts of the index. * * @return the maximum number of bytes allowed; this limit includes the * composite of all the constituent parts of the index; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxIndexLength() throws SQLException; /** * Retrieves the maximum number of characters that this database allows in a * schema name. * * @return the maximum number of characters allowed in a schema name; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxSchemaNameLength() throws SQLException; /** * Retrieves the maximum number of characters that this database allows in a * procedure name. * * @return the maximum number of characters allowed in a procedure name; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxProcedureNameLength() throws SQLException; /** * Retrieves the maximum number of characters that this database allows in a * catalog name. * * @return the maximum number of characters allowed in a catalog name; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxCatalogNameLength() throws SQLException; /** * Retrieves the maximum number of bytes this database allows in * a single row. * * @return the maximum number of bytes allowed for a row; a result of * zero means that there is no limit or the limit is not known * @throws SQLException if a database access error occurs */ int getMaxRowSize() throws SQLException; /** * Retrieves whether the return value for the method * {@code getMaxRowSize} includes the SQL data types * {@code LONGVARCHAR} and {@code LONGVARBINARY}. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean doesMaxRowSizeIncludeBlobs() throws SQLException; /** * Retrieves the maximum number of characters this database allows in * an SQL statement. * * @return the maximum number of characters allowed for an SQL statement; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxStatementLength() throws SQLException; /** * Retrieves the maximum number of active statements to this database * that can be open at the same time. * * @return the maximum number of statements that can be open at one time; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxStatements() throws SQLException; /** * Retrieves the maximum number of characters this database allows in * a table name. * * @return the maximum number of characters allowed for a table name; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxTableNameLength() throws SQLException; /** * Retrieves the maximum number of tables this database allows in a * {@code SELECT} statement. * * @return the maximum number of tables allowed in a {@code SELECT} * statement; a result of zero means that there is no limit or * the limit is not known * @throws SQLException if a database access error occurs */ int getMaxTablesInSelect() throws SQLException; /** * Retrieves the maximum number of characters this database allows in * a user name. * * @return the maximum number of characters allowed for a user name; * a result of zero means that there is no limit or the limit * is not known * @throws SQLException if a database access error occurs */ int getMaxUserNameLength() throws SQLException; //---------------------------------------------------------------------- /** * Retrieves this database's default transaction isolation level. The * possible values are defined in {@code java.sql.Connection}. * * @return the default isolation level * @throws SQLException if a database access error occurs * @see Connection */ int getDefaultTransactionIsolation() throws SQLException; /** * Retrieves whether this database supports transactions. If not, invoking the * method {@code commit} is a noop, and the isolation level is * {@code TRANSACTION_NONE}. * * @return {@code true} if transactions are supported; * {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsTransactions() throws SQLException; /** * Retrieves whether this database supports the given transaction isolation level. * * @param level one of the transaction isolation levels defined in * {@code java.sql.Connection} * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs * @see Connection */ boolean supportsTransactionIsolationLevel(int level) throws SQLException; /** * Retrieves whether this database supports both data definition and * data manipulation statements within a transaction. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsDataDefinitionAndDataManipulationTransactions() throws SQLException; /** * Retrieves whether this database supports only data manipulation * statements within a transaction. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean supportsDataManipulationTransactionsOnly() throws SQLException; /** * Retrieves whether a data definition statement within a transaction forces * the transaction to commit. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean dataDefinitionCausesTransactionCommit() throws SQLException; /** * Retrieves whether this database ignores a data definition statement * within a transaction. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs */ boolean dataDefinitionIgnoredInTransactions() throws SQLException; /** * Retrieves a description of the stored procedures available in the given * catalog. *
* Only procedure descriptions matching the schema and * procedure name criteria are returned. They are ordered by * {@code PROCEDURE_CAT}, {@code PROCEDURE_SCHEM}, * {@code PROCEDURE_NAME} and {@code SPECIFIC_NAME}. * *
Each procedure description has the following columns: *
* A user may not have permissions to execute any of the procedures that are * returned by {@code getProcedures} * * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema name pattern; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param procedureNamePattern a procedure name pattern; must match the * procedure name as it is stored in the database * @return {@code ResultSet} - each row is a procedure description * @throws SQLException if a database access error occurs * @see #getSearchStringEscape */ ResultSet getProcedures(String catalog, String schemaPattern, String procedureNamePattern) throws SQLException; /** * Indicates that it is not known whether the procedure returns * a result. *
* A possible value for column {@code PROCEDURE_TYPE} in the * {@code ResultSet} object returned by the method * {@code getProcedures}. */ int procedureResultUnknown = 0; /** * Indicates that the procedure does not return a result. *
* A possible value for column {@code PROCEDURE_TYPE} in the * {@code ResultSet} object returned by the method * {@code getProcedures}. */ int procedureNoResult = 1; /** * Indicates that the procedure returns a result. *
* A possible value for column {@code PROCEDURE_TYPE} in the * {@code ResultSet} object returned by the method * {@code getProcedures}. */ int procedureReturnsResult = 2; /** * Retrieves a description of the given catalog's stored procedure parameter * and result columns. * *
Only descriptions matching the schema, procedure and * parameter name criteria are returned. They are ordered by * PROCEDURE_CAT, PROCEDURE_SCHEM, PROCEDURE_NAME and SPECIFIC_NAME. Within this, the return value, * if any, is first. Next are the parameter descriptions in call * order. The column descriptions follow in column number order. * *
Each row in the {@code ResultSet} is a parameter description or * column description with the following fields: *
Note: Some databases may not return the column * descriptions for a procedure. * *
The PRECISION column represents the specified column size for the given column. * For numeric data, this is the maximum precision. For character data, this is the length in characters. * For datetime datatypes, this is the length in characters of the String representation (assuming the * maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID datatype, * this is the length in bytes. Null is returned for data types where the * column size is not applicable. * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema name pattern; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param procedureNamePattern a procedure name pattern; must match the * procedure name as it is stored in the database * @param columnNamePattern a column name pattern; must match the column name * as it is stored in the database * @return {@code ResultSet} - each row describes a stored procedure parameter or * column * @throws SQLException if a database access error occurs * @see #getSearchStringEscape */ ResultSet getProcedureColumns(String catalog, String schemaPattern, String procedureNamePattern, String columnNamePattern) throws SQLException; /** * Indicates that type of the column is unknown. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getProcedureColumns}. */ int procedureColumnUnknown = 0; /** * Indicates that the column stores IN parameters. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getProcedureColumns}. */ int procedureColumnIn = 1; /** * Indicates that the column stores INOUT parameters. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getProcedureColumns}. */ int procedureColumnInOut = 2; /** * Indicates that the column stores OUT parameters. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getProcedureColumns}. */ int procedureColumnOut = 4; /** * Indicates that the column stores return values. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getProcedureColumns}. */ int procedureColumnReturn = 5; /** * Indicates that the column stores results. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getProcedureColumns}. */ int procedureColumnResult = 3; /** * Indicates that {@code NULL} values are not allowed. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getProcedureColumns}. */ int procedureNoNulls = 0; /** * Indicates that {@code NULL} values are allowed. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getProcedureColumns}. */ int procedureNullable = 1; /** * Indicates that whether {@code NULL} values are allowed * is unknown. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getProcedureColumns}. */ int procedureNullableUnknown = 2; /** * Retrieves a description of the tables available in the given catalog. * Only table descriptions matching the catalog, schema, table * name and type criteria are returned. They are ordered by * {@code TABLE_TYPE}, {@code TABLE_CAT}, * {@code TABLE_SCHEM} and {@code TABLE_NAME}. *
* Each table description has the following columns: *
Note: Some databases may not return information for * all tables. * * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema name pattern; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param tableNamePattern a table name pattern; must match the * table name as it is stored in the database * @param types a list of table types, which must be from the list of table types * returned from {@link #getTableTypes}, to include; {@code null} returns * all types * @return {@code ResultSet} - each row is a table description * @throws SQLException if a database access error occurs * @see #getSearchStringEscape */ ResultSet getTables(String catalog, String schemaPattern, String tableNamePattern, String types[]) throws SQLException; /** * Retrieves the schema names available in this database. The results * are ordered by {@code TABLE_CATALOG} and * {@code TABLE_SCHEM}. * *
The schema columns are: *
The catalog column is: *
The table type is: *
Only column descriptions matching the catalog, schema, table * and column name criteria are returned. They are ordered by * {@code TABLE_CAT},{@code TABLE_SCHEM}, * {@code TABLE_NAME}, and {@code ORDINAL_POSITION}. * *
Each column description has the following columns: *
The COLUMN_SIZE column specifies the column size for the given column. * For numeric data, this is the maximum precision. For character data, this is the length in characters. * For datetime datatypes, this is the length in characters of the String representation (assuming the * maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID datatype, * this is the length in bytes. Null is returned for data types where the * column size is not applicable. * * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema name pattern; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param tableNamePattern a table name pattern; must match the * table name as it is stored in the database * @param columnNamePattern a column name pattern; must match the column * name as it is stored in the database * @return {@code ResultSet} - each row is a column description * @throws SQLException if a database access error occurs * @see #getSearchStringEscape */ ResultSet getColumns(String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern) throws SQLException; /** * Indicates that the column might not allow {@code NULL} values. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} returned by the method * {@code getColumns}. */ int columnNoNulls = 0; /** * Indicates that the column definitely allows {@code NULL} values. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} returned by the method * {@code getColumns}. */ int columnNullable = 1; /** * Indicates that the nullability of columns is unknown. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} returned by the method * {@code getColumns}. */ int columnNullableUnknown = 2; /** * Retrieves a description of the access rights for a table's columns. * *
Only privileges matching the column name criteria are * returned. They are ordered by COLUMN_NAME and PRIVILEGE. * *
Each privilege description has the following columns: *
Only privileges matching the schema and table name * criteria are returned. They are ordered by * {@code TABLE_CAT}, * {@code TABLE_SCHEM}, {@code TABLE_NAME}, * and {@code PRIVILEGE}. * *
Each privilege description has the following columns: *
Each column description has the following columns: *
The COLUMN_SIZE column represents the specified column size for the given column. * For numeric data, this is the maximum precision. For character data, this is the length in characters. * For datetime datatypes, this is the length in characters of the String representation (assuming the * maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID datatype, * this is the length in bytes. Null is returned for data types where the * column size is not applicable. * * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schema a schema name; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param table a table name; must match the table name as it is stored * in the database * @param scope the scope of interest; use same values as SCOPE * @param nullable include columns that are nullable. * @return {@code ResultSet} - each row is a column description * @throws SQLException if a database access error occurs */ ResultSet getBestRowIdentifier(String catalog, String schema, String table, int scope, boolean nullable) throws SQLException; /** * Indicates that the scope of the best row identifier is * very temporary, lasting only while the * row is being used. *
* A possible value for the column * {@code SCOPE} * in the {@code ResultSet} object * returned by the method {@code getBestRowIdentifier}. */ int bestRowTemporary = 0; /** * Indicates that the scope of the best row identifier is * the remainder of the current transaction. *
* A possible value for the column * {@code SCOPE} * in the {@code ResultSet} object * returned by the method {@code getBestRowIdentifier}. */ int bestRowTransaction = 1; /** * Indicates that the scope of the best row identifier is * the remainder of the current session. *
* A possible value for the column * {@code SCOPE} * in the {@code ResultSet} object * returned by the method {@code getBestRowIdentifier}. */ int bestRowSession = 2; /** * Indicates that the best row identifier may or may not be a pseudo column. *
* A possible value for the column * {@code PSEUDO_COLUMN} * in the {@code ResultSet} object * returned by the method {@code getBestRowIdentifier}. */ int bestRowUnknown = 0; /** * Indicates that the best row identifier is NOT a pseudo column. *
* A possible value for the column * {@code PSEUDO_COLUMN} * in the {@code ResultSet} object * returned by the method {@code getBestRowIdentifier}. */ int bestRowNotPseudo = 1; /** * Indicates that the best row identifier is a pseudo column. *
* A possible value for the column * {@code PSEUDO_COLUMN} * in the {@code ResultSet} object * returned by the method {@code getBestRowIdentifier}. */ int bestRowPseudo = 2; /** * Retrieves a description of a table's columns that are automatically * updated when any value in a row is updated. They are * unordered. * *
Each column description has the following columns: *
The COLUMN_SIZE column represents the specified column size for the given column. * For numeric data, this is the maximum precision. For character data, this is the length in characters. * For datetime datatypes, this is the length in characters of the String representation (assuming the * maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID datatype, * this is the length in bytes. Null is returned for data types where the * column size is not applicable. * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schema a schema name; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param table a table name; must match the table name as it is stored * in the database * @return a {@code ResultSet} object in which each row is a * column description * @throws SQLException if a database access error occurs */ ResultSet getVersionColumns(String catalog, String schema, String table) throws SQLException; /** * Indicates that this version column may or may not be a pseudo column. *
* A possible value for the column * {@code PSEUDO_COLUMN} * in the {@code ResultSet} object * returned by the method {@code getVersionColumns}. */ int versionColumnUnknown = 0; /** * Indicates that this version column is NOT a pseudo column. *
* A possible value for the column * {@code PSEUDO_COLUMN} * in the {@code ResultSet} object * returned by the method {@code getVersionColumns}. */ int versionColumnNotPseudo = 1; /** * Indicates that this version column is a pseudo column. *
* A possible value for the column * {@code PSEUDO_COLUMN} * in the {@code ResultSet} object * returned by the method {@code getVersionColumns}. */ int versionColumnPseudo = 2; /** * Retrieves a description of the given table's primary key columns. They * are ordered by COLUMN_NAME. * *
Each primary key column description has the following columns: *
Each primary key column description has the following columns: *
* A possible value for the columns {@code UPDATE_RULE} * and {@code DELETE_RULE} in the * {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeyCascade = 0; /** * For the column {@code UPDATE_RULE}, indicates that * a primary key may not be updated if it has been imported by * another table as a foreign key. * For the column {@code DELETE_RULE}, indicates that * a primary key may not be deleted if it has been imported by * another table as a foreign key. *
* A possible value for the columns {@code UPDATE_RULE} * and {@code DELETE_RULE} in the * {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeyRestrict = 1; /** * For the columns {@code UPDATE_RULE} * and {@code DELETE_RULE}, indicates that * when the primary key is updated or deleted, the foreign key (imported key) * is changed to {@code NULL}. *
* A possible value for the columns {@code UPDATE_RULE} * and {@code DELETE_RULE} in the * {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeySetNull = 2; /** * For the columns {@code UPDATE_RULE} * and {@code DELETE_RULE}, indicates that * if the primary key has been imported, it cannot be updated or deleted. *
* A possible value for the columns {@code UPDATE_RULE} * and {@code DELETE_RULE} in the * {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeyNoAction = 3; /** * For the columns {@code UPDATE_RULE} * and {@code DELETE_RULE}, indicates that * if the primary key is updated or deleted, the foreign key (imported key) * is set to the default value. *
* A possible value for the columns {@code UPDATE_RULE} * and {@code DELETE_RULE} in the * {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeySetDefault = 4; /** * Indicates deferrability. See SQL-92 for a definition. *
* A possible value for the column {@code DEFERRABILITY} * in the {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeyInitiallyDeferred = 5; /** * Indicates deferrability. See SQL-92 for a definition. *
* A possible value for the column {@code DEFERRABILITY} * in the {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeyInitiallyImmediate = 6; /** * Indicates deferrability. See SQL-92 for a definition. *
* A possible value for the column {@code DEFERRABILITY} * in the {@code ResultSet} objects returned by the methods * {@code getImportedKeys}, {@code getExportedKeys}, * and {@code getCrossReference}. */ int importedKeyNotDeferrable = 7; /** * Retrieves a description of the foreign key columns that reference the * given table's primary key columns (the foreign keys exported by a * table). They are ordered by FKTABLE_CAT, FKTABLE_SCHEM, * FKTABLE_NAME, and KEY_SEQ. * *
Each foreign key column description has the following columns: *
Each foreign key column description has the following columns: *
If the database supports SQL distinct types, then getTypeInfo() will return * a single row with a TYPE_NAME of DISTINCT and a DATA_TYPE of Types.DISTINCT. * If the database supports SQL structured types, then getTypeInfo() will return * a single row with a TYPE_NAME of STRUCT and a DATA_TYPE of Types.STRUCT. * *
If SQL distinct or structured types are supported, then information on the * individual types may be obtained from the getUDTs() method. * * *
Each type description has the following columns: *
The PRECISION column represents the maximum column size that the server supports for the given datatype. * For numeric data, this is the maximum precision. For character data, this is the length in characters. * For datetime datatypes, this is the length in characters of the String representation (assuming the * maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID datatype, * this is the length in bytes. Null is returned for data types where the * column size is not applicable. * * @return a {@code ResultSet} object in which each row is an SQL * type description * @throws SQLException if a database access error occurs */ ResultSet getTypeInfo() throws SQLException; /** * Indicates that a {@code NULL} value is NOT allowed for this * data type. *
* A possible value for column {@code NULLABLE} in the * {@code ResultSet} object returned by the method * {@code getTypeInfo}. */ int typeNoNulls = 0; /** * Indicates that a {@code NULL} value is allowed for this * data type. *
* A possible value for column {@code NULLABLE} in the * {@code ResultSet} object returned by the method * {@code getTypeInfo}. */ int typeNullable = 1; /** * Indicates that it is not known whether a {@code NULL} value * is allowed for this data type. *
* A possible value for column {@code NULLABLE} in the * {@code ResultSet} object returned by the method * {@code getTypeInfo}. */ int typeNullableUnknown = 2; /** * Indicates that {@code WHERE} search clauses are not supported * for this type. *
* A possible value for column {@code SEARCHABLE} in the * {@code ResultSet} object returned by the method * {@code getTypeInfo}. */ int typePredNone = 0; /** * Indicates that the data type * can be only be used in {@code WHERE} search clauses * that use {@code LIKE} predicates. *
* A possible value for column {@code SEARCHABLE} in the * {@code ResultSet} object returned by the method * {@code getTypeInfo}. */ int typePredChar = 1; /** * Indicates that the data type can be only be used in {@code WHERE} * search clauses * that do not use {@code LIKE} predicates. *
* A possible value for column {@code SEARCHABLE} in the * {@code ResultSet} object returned by the method * {@code getTypeInfo}. */ int typePredBasic = 2; /** * Indicates that all {@code WHERE} search clauses can be * based on this type. *
* A possible value for column {@code SEARCHABLE} in the * {@code ResultSet} object returned by the method * {@code getTypeInfo}. */ int typeSearchable = 3; /** * Retrieves a description of the given table's indices and statistics. They are * ordered by NON_UNIQUE, TYPE, INDEX_NAME, and ORDINAL_POSITION. * *
Each index column description has the following columns: *
* A possible value for column {@code TYPE} in the * {@code ResultSet} object returned by the method * {@code getIndexInfo}. */ short tableIndexStatistic = 0; /** * Indicates that this table index is a clustered index. *
* A possible value for column {@code TYPE} in the * {@code ResultSet} object returned by the method * {@code getIndexInfo}. */ short tableIndexClustered = 1; /** * Indicates that this table index is a hashed index. *
* A possible value for column {@code TYPE} in the * {@code ResultSet} object returned by the method * {@code getIndexInfo}. */ short tableIndexHashed = 2; /** * Indicates that this table index is not a clustered * index, a hashed index, or table statistics; * it is something other than these. *
* A possible value for column {@code TYPE} in the * {@code ResultSet} object returned by the method * {@code getIndexInfo}. */ short tableIndexOther = 3; //--------------------------JDBC 2.0----------------------------- /** * Retrieves whether this database supports the given result set type. * * @param type defined in {@code java.sql.ResultSet} * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs * @see Connection * @since 1.2 */ boolean supportsResultSetType(int type) throws SQLException; /** * Retrieves whether this database supports the given concurrency type * in combination with the given result set type. * * @param type defined in {@code java.sql.ResultSet} * @param concurrency type defined in {@code java.sql.ResultSet} * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs * @see Connection * @since 1.2 */ boolean supportsResultSetConcurrency(int type, int concurrency) throws SQLException; /** * * Retrieves whether for the given type of {@code ResultSet} object, * the result set's own updates are visible. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if updates are visible for the given result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean ownUpdatesAreVisible(int type) throws SQLException; /** * Retrieves whether a result set's own deletes are visible. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if deletes are visible for the given result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean ownDeletesAreVisible(int type) throws SQLException; /** * Retrieves whether a result set's own inserts are visible. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if inserts are visible for the given result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean ownInsertsAreVisible(int type) throws SQLException; /** * Retrieves whether updates made by others are visible. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if updates made by others * are visible for the given result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean othersUpdatesAreVisible(int type) throws SQLException; /** * Retrieves whether deletes made by others are visible. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if deletes made by others * are visible for the given result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean othersDeletesAreVisible(int type) throws SQLException; /** * Retrieves whether inserts made by others are visible. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if inserts made by others * are visible for the given result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean othersInsertsAreVisible(int type) throws SQLException; /** * Retrieves whether or not a visible row update can be detected by * calling the method {@code ResultSet.rowUpdated}. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if changes are detected by the result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean updatesAreDetected(int type) throws SQLException; /** * Retrieves whether or not a visible row delete can be detected by * calling the method {@code ResultSet.rowDeleted}. If the method * {@code deletesAreDetected} returns {@code false}, it means that * deleted rows are removed from the result set. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if deletes are detected by the given result set type; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean deletesAreDetected(int type) throws SQLException; /** * Retrieves whether or not a visible row insert can be detected * by calling the method {@code ResultSet.rowInserted}. * * @param type the {@code ResultSet} type; one of * {@code ResultSet.TYPE_FORWARD_ONLY}, * {@code ResultSet.TYPE_SCROLL_INSENSITIVE}, or * {@code ResultSet.TYPE_SCROLL_SENSITIVE} * @return {@code true} if changes are detected by the specified result * set type; {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean insertsAreDetected(int type) throws SQLException; /** * Retrieves whether this database supports batch updates. * * @return {@code true} if this database supports batch updates; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.2 */ boolean supportsBatchUpdates() throws SQLException; /** * Retrieves a description of the user-defined types (UDTs) defined * in a particular schema. Schema-specific UDTs may have type * {@code JAVA_OBJECT}, {@code STRUCT}, * or {@code DISTINCT}. * *
Only types matching the catalog, schema, type name and type * criteria are returned. They are ordered by {@code DATA_TYPE}, * {@code TYPE_CAT}, {@code TYPE_SCHEM} and * {@code TYPE_NAME}. The type name parameter may be a fully-qualified * name. In this case, the catalog and schemaPattern parameters are * ignored. * *
Each type description has the following columns: *
Note: If the driver does not support UDTs, an empty * result set is returned. * * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema pattern name; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param typeNamePattern a type name pattern; must match the type name * as it is stored in the database; may be a fully qualified name * @param types a list of user-defined types (JAVA_OBJECT, * STRUCT, or DISTINCT) to include; {@code null} returns all types * @return {@code ResultSet} object in which each row describes a UDT * @throws SQLException if a database access error occurs * @see #getSearchStringEscape * @since 1.2 */ ResultSet getUDTs(String catalog, String schemaPattern, String typeNamePattern, int[] types) throws SQLException; /** * Retrieves the connection that produced this metadata object. * * @return the connection that produced this metadata object * @throws SQLException if a database access error occurs * @since 1.2 */ Connection getConnection() throws SQLException; // ------------------- JDBC 3.0 ------------------------- /** * Retrieves whether this database supports savepoints. * * @return {@code true} if savepoints are supported; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.4 */ boolean supportsSavepoints() throws SQLException; /** * Retrieves whether this database supports named parameters to callable * statements. * * @return {@code true} if named parameters are supported; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.4 */ boolean supportsNamedParameters() throws SQLException; /** * Retrieves whether it is possible to have multiple {@code ResultSet} objects * returned from a {@code CallableStatement} object * simultaneously. * * @return {@code true} if a {@code CallableStatement} object * can return multiple {@code ResultSet} objects * simultaneously; {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.4 */ boolean supportsMultipleOpenResults() throws SQLException; /** * Retrieves whether auto-generated keys can be retrieved after * a statement has been executed * * @return {@code true} if auto-generated keys can be retrieved * after a statement has executed; {@code false} otherwise *
If {@code true} is returned, the JDBC driver must support the * returning of auto-generated keys for at least SQL INSERT statements * * @throws SQLException if a database access error occurs * @since 1.4 */ boolean supportsGetGeneratedKeys() throws SQLException; /** * Retrieves a description of the user-defined type (UDT) hierarchies defined in a * particular schema in this database. Only the immediate super type/ * sub type relationship is modeled. *
* Only supertype information for UDTs matching the catalog, * schema, and type name is returned. The type name parameter * may be a fully-qualified name. When the UDT name supplied is a * fully-qualified name, the catalog and schemaPattern parameters are * ignored. *
* If a UDT does not have a direct super type, it is not listed here. * A row of the {@code ResultSet} object returned by this method * describes the designated UDT and a direct supertype. A row has the following * columns: *
Note: If the driver does not support type hierarchies, an * empty result set is returned. * * @param catalog a catalog name; "" retrieves those without a catalog; * {@code null} means drop catalog name from the selection criteria * @param schemaPattern a schema name pattern; "" retrieves those * without a schema * @param typeNamePattern a UDT name pattern; may be a fully-qualified * name * @return a {@code ResultSet} object in which a row gives information * about the designated UDT * @throws SQLException if a database access error occurs * @see #getSearchStringEscape * @since 1.4 */ ResultSet getSuperTypes(String catalog, String schemaPattern, String typeNamePattern) throws SQLException; /** * Retrieves a description of the table hierarchies defined in a particular * schema in this database. * *
Only supertable information for tables matching the catalog, schema * and table name are returned. The table name parameter may be a fully- * qualified name, in which case, the catalog and schemaPattern parameters * are ignored. If a table does not have a super table, it is not listed here. * Supertables have to be defined in the same catalog and schema as the * sub tables. Therefore, the type description does not need to include * this information for the supertable. * *
Each type description has the following columns: *
Note: If the driver does not support type hierarchies, an * empty result set is returned. * * @param catalog a catalog name; "" retrieves those without a catalog; * {@code null} means drop catalog name from the selection criteria * @param schemaPattern a schema name pattern; "" retrieves those * without a schema * @param tableNamePattern a table name pattern; may be a fully-qualified * name * @return a {@code ResultSet} object in which each row is a type description * @throws SQLException if a database access error occurs * @see #getSearchStringEscape * @since 1.4 */ ResultSet getSuperTables(String catalog, String schemaPattern, String tableNamePattern) throws SQLException; /** * Indicates that {@code NULL} values might not be allowed. *
* A possible value for the column * {@code NULLABLE} in the {@code ResultSet} object * returned by the method {@code getAttributes}. */ short attributeNoNulls = 0; /** * Indicates that {@code NULL} values are definitely allowed. *
* A possible value for the column {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getAttributes}. */ short attributeNullable = 1; /** * Indicates that whether {@code NULL} values are allowed is not * known. *
* A possible value for the column {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getAttributes}. */ short attributeNullableUnknown = 2; /** * Retrieves a description of the given attribute of the given type * for a user-defined type (UDT) that is available in the given schema * and catalog. *
* Descriptions are returned only for attributes of UDTs matching the * catalog, schema, type, and attribute name criteria. They are ordered by * {@code TYPE_CAT}, {@code TYPE_SCHEM}, * {@code TYPE_NAME} and {@code ORDINAL_POSITION}. This description * does not contain inherited attributes. *
* The {@code ResultSet} object that is returned has the following * columns: *
* Note:This constant remains only for compatibility reasons. Developers * should use the constant {@code sqlStateSQL} instead. * * @since 1.4 */ int sqlStateSQL99 = sqlStateSQL; /** * Indicates whether the SQLSTATE returned by {@code SQLException.getSQLState} * is X/Open (now known as Open Group) SQL CLI or SQL:2003. * @return the type of SQLSTATE; one of: * sqlStateXOpen or * sqlStateSQL * @throws SQLException if a database access error occurs * @since 1.4 */ int getSQLStateType() throws SQLException; /** * Indicates whether updates made to a LOB are made on a copy or directly * to the LOB. * @return {@code true} if updates are made to a copy of the LOB; * {@code false} if updates are made directly to the LOB * @throws SQLException if a database access error occurs * @since 1.4 */ boolean locatorsUpdateCopy() throws SQLException; /** * Retrieves whether this database supports statement pooling. * * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.4 */ boolean supportsStatementPooling() throws SQLException; //------------------------- JDBC 4.0 ----------------------------------- /** * Indicates whether this data source supports the SQL {@code ROWID} type, * and the lifetime for which a {@link RowId} object remains valid. * * @return the status indicating the lifetime of a {@code RowId} * @throws SQLException if a database access error occurs * @since 1.6 */ RowIdLifetime getRowIdLifetime() throws SQLException; /** * Retrieves the schema names available in this database. The results * are ordered by {@code TABLE_CATALOG} and * {@code TABLE_SCHEM}. * *
The schema columns are: *
* The {@code ResultSet} is sorted by the NAME column * * @return A {@code ResultSet} object; each row is a supported client info * property * * @throws SQLException if a database access error occurs * * @since 1.6 */ ResultSet getClientInfoProperties() throws SQLException; /** * Retrieves a description of the system and user functions available * in the given catalog. *
* Only system and user function descriptions matching the schema and * function name criteria are returned. They are ordered by * {@code FUNCTION_CAT}, {@code FUNCTION_SCHEM}, * {@code FUNCTION_NAME} and * {@code SPECIFIC_NAME}. * *
Each function description has the following columns: *
* A user may not have permission to execute any of the functions that are * returned by {@code getFunctions} * * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema name pattern; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param functionNamePattern a function name pattern; must match the * function name as it is stored in the database * @return {@code ResultSet} - each row is a function description * @throws SQLException if a database access error occurs * @see #getSearchStringEscape * @since 1.6 */ ResultSet getFunctions(String catalog, String schemaPattern, String functionNamePattern) throws SQLException; /** * Retrieves a description of the given catalog's system or user * function parameters and return type. * *
Only descriptions matching the schema, function and * parameter name criteria are returned. They are ordered by * {@code FUNCTION_CAT}, {@code FUNCTION_SCHEM}, * {@code FUNCTION_NAME} and * {@code SPECIFIC_NAME}. Within this, the return value, * if any, is first. Next are the parameter descriptions in call * order. The column descriptions follow in column number order. * *
Each row in the {@code ResultSet} * is a parameter description, column description or * return type description with the following fields: *
The PRECISION column represents the specified column size for the given * parameter or column. * For numeric data, this is the maximum precision. For character data, this is the length in characters. * For datetime datatypes, this is the length in characters of the String representation (assuming the * maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID datatype, * this is the length in bytes. Null is returned for data types where the * column size is not applicable. * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema name pattern; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param functionNamePattern a procedure name pattern; must match the * function name as it is stored in the database * @param columnNamePattern a parameter name pattern; must match the * parameter or column name as it is stored in the database * @return {@code ResultSet} - each row describes a * user function parameter, column or return type * * @throws SQLException if a database access error occurs * @see #getSearchStringEscape * @since 1.6 */ ResultSet getFunctionColumns(String catalog, String schemaPattern, String functionNamePattern, String columnNamePattern) throws SQLException; /** * Indicates that type of the parameter or column is unknown. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getFunctionColumns}. */ int functionColumnUnknown = 0; /** * Indicates that the parameter or column is an IN parameter. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionColumnIn = 1; /** * Indicates that the parameter or column is an INOUT parameter. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionColumnInOut = 2; /** * Indicates that the parameter or column is an OUT parameter. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionColumnOut = 3; /** * Indicates that the parameter or column is a return value. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionReturn = 4; /** * Indicates that the parameter or column is a column in a result set. *
* A possible value for the column * {@code COLUMN_TYPE} * in the {@code ResultSet} * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionColumnResult = 5; /** * Indicates that {@code NULL} values are not allowed. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionNoNulls = 0; /** * Indicates that {@code NULL} values are allowed. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionNullable = 1; /** * Indicates that whether {@code NULL} values are allowed * is unknown. *
* A possible value for the column * {@code NULLABLE} * in the {@code ResultSet} object * returned by the method {@code getFunctionColumns}. * @since 1.6 */ int functionNullableUnknown = 2; /** * Indicates that it is not known whether the function returns * a result or a table. *
* A possible value for column {@code FUNCTION_TYPE} in the * {@code ResultSet} object returned by the method * {@code getFunctions}. * @since 1.6 */ int functionResultUnknown = 0; /** * Indicates that the function does not return a table. *
* A possible value for column {@code FUNCTION_TYPE} in the * {@code ResultSet} object returned by the method * {@code getFunctions}. * @since 1.6 */ int functionNoTable = 1; /** * Indicates that the function returns a table. *
* A possible value for column {@code FUNCTION_TYPE} in the * {@code ResultSet} object returned by the method * {@code getFunctions}. * @since 1.6 */ int functionReturnsTable = 2; //--------------------------JDBC 4.1 ----------------------------- /** * Retrieves a description of the pseudo or hidden columns available * in a given table within the specified catalog and schema. * Pseudo or hidden columns may not always be stored within * a table and are not visible in a ResultSet unless they are * specified in the query's outermost SELECT list. Pseudo or hidden * columns may not necessarily be able to be modified. If there are * no pseudo or hidden columns, an empty ResultSet is returned. * *
Only column descriptions matching the catalog, schema, table * and column name criteria are returned. They are ordered by * {@code TABLE_CAT},{@code TABLE_SCHEM}, {@code TABLE_NAME} * and {@code COLUMN_NAME}. * *
Each column description has the following columns: *
The COLUMN_SIZE column specifies the column size for the given column. * For numeric data, this is the maximum precision. For character data, this is the length in characters. * For datetime datatypes, this is the length in characters of the String representation (assuming the * maximum allowed precision of the fractional seconds component). For binary data, this is the length in bytes. For the ROWID datatype, * this is the length in bytes. Null is returned for data types where the * column size is not applicable. * * @param catalog a catalog name; must match the catalog name as it * is stored in the database; "" retrieves those without a catalog; * {@code null} means that the catalog name should not be used to narrow * the search * @param schemaPattern a schema name pattern; must match the schema name * as it is stored in the database; "" retrieves those without a schema; * {@code null} means that the schema name should not be used to narrow * the search * @param tableNamePattern a table name pattern; must match the * table name as it is stored in the database * @param columnNamePattern a column name pattern; must match the column * name as it is stored in the database * @return {@code ResultSet} - each row is a column description * @throws SQLException if a database access error occurs * @see PseudoColumnUsage * @since 1.7 */ ResultSet getPseudoColumns(String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern) throws SQLException; /** * Retrieves whether a generated key will always be returned if the column * name(s) or index(es) specified for the auto generated key column(s) * are valid and the statement succeeds. The key that is returned may or * may not be based on the column(s) for the auto generated key. * Consult your JDBC driver documentation for additional details. * @return {@code true} if so; {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.7 */ boolean generatedKeyAlwaysReturned() throws SQLException; //--------------------------JDBC 4.2 ----------------------------- /** * * Retrieves the maximum number of bytes this database allows for * the logical size for a {@code LOB}. *
* The default implementation will return {@code 0} * * @return the maximum number of bytes allowed; a result of zero * means that there is no limit or the limit is not known * @throws SQLException if a database access error occurs * @since 1.8 */ default long getMaxLogicalLobSize() throws SQLException { return 0; } /** * Retrieves whether this database supports REF CURSOR. *
* The default implementation will return {@code false} * * @return {@code true} if this database supports REF CURSOR; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 1.8 */ default boolean supportsRefCursors() throws SQLException{ return false; } // JDBC 4.3 /** * Retrieves whether this database supports sharding. * @implSpec * The default implementation will return {@code false} * * @return {@code true} if this database supports sharding; * {@code false} otherwise * @throws SQLException if a database access error occurs * @since 9 */ default boolean supportsSharding() throws SQLException { return false; } }