public class PgDatabaseMetaData extends Object implements DatabaseMetaData
| Modifier and Type | Field and Description |
|---|---|
protected PgConnection |
connection |
attributeNoNulls, attributeNullable, attributeNullableUnknown, bestRowNotPseudo, bestRowPseudo, bestRowSession, bestRowTemporary, bestRowTransaction, bestRowUnknown, columnNoNulls, columnNullable, columnNullableUnknown, functionColumnIn, functionColumnInOut, functionColumnOut, functionColumnResult, functionColumnUnknown, functionNoNulls, functionNoTable, functionNullable, functionNullableUnknown, functionResultUnknown, functionReturn, functionReturnsTable, importedKeyCascade, importedKeyInitiallyDeferred, importedKeyInitiallyImmediate, importedKeyNoAction, importedKeyNotDeferrable, importedKeyRestrict, importedKeySetDefault, importedKeySetNull, procedureColumnIn, procedureColumnInOut, procedureColumnOut, procedureColumnResult, procedureColumnReturn, procedureColumnUnknown, procedureNoNulls, procedureNoResult, procedureNullable, procedureNullableUnknown, procedureResultUnknown, procedureReturnsResult, sqlStateSQL, sqlStateSQL99, sqlStateXOpen, tableIndexClustered, tableIndexHashed, tableIndexOther, tableIndexStatistic, typeNoNulls, typeNullable, typeNullableUnknown, typePredBasic, typePredChar, typePredNone, typeSearchable, versionColumnNotPseudo, versionColumnPseudo, versionColumnUnknown| Constructor and Description |
|---|
PgDatabaseMetaData(PgConnection conn) |
| Modifier and Type | Method and Description |
|---|---|
boolean |
allProceduresAreCallable()
Retrieves whether the current user can call all the procedures
returned by the method
getProcedures. |
boolean |
allTablesAreSelectable()
Retrieves whether the current user can use all the tables returned
by the method
getTables in a SELECT
statement. |
boolean |
autoCommitFailureClosesAllResultSets()
Retrieves whether a
SQLException while autoCommit is true inidcates
that all open ResultSets are closed, even ones that are holdable. |
protected Statement |
createMetaDataStatement() |
boolean |
dataDefinitionCausesTransactionCommit()
Does a data definition statement within a transaction force the transaction to commit?
|
boolean |
dataDefinitionIgnoredInTransactions()
Retrieves whether this database ignores a data definition statement
within a transaction.
|
boolean |
deletesAreDetected(int i)
Retrieves whether or not a visible row delete can be detected by
calling the method
ResultSet.rowDeleted. |
boolean |
doesMaxRowSizeIncludeBlobs()
Retrieves whether the return value for the method
getMaxRowSize includes the SQL data types
LONGVARCHAR and LONGVARBINARY. |
protected String |
escapeQuotes(String s)
Turn the provided value into a valid string literal for direct inclusion into a query.
|
boolean |
generatedKeyAlwaysReturned()
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.
|
ResultSet |
getAttributes(String catalog,
String schemaPattern,
String typeNamePattern,
String attributeNamePattern)
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.
|
ResultSet |
getBestRowIdentifier(String catalog,
String schema,
String table,
int scope,
boolean nullable)
Retrieves a description of a table's optimal set of columns that
uniquely identifies a row.
|
ResultSet |
getCatalogs()
PostgreSQL does not support multiple catalogs from a single connection, so to reduce confusion
we only return the current catalog.
|
String |
getCatalogSeparator()
Retrieves the
String that this database uses as the
separator between a catalog and table name. |
String |
getCatalogTerm()
Retrieves the database vendor's preferred term for "catalog".
|
ResultSet |
getClientInfoProperties()
Retrieves a list of the client info properties
that the driver supports.
|
ResultSet |
getColumnPrivileges(String catalog,
String schema,
String table,
String columnNamePattern)
Retrieves a description of the access rights for a table's columns.
|
ResultSet |
getColumns(String catalog,
String schemaPattern,
String tableNamePattern,
String columnNamePattern)
Retrieves a description of table columns available in
the specified catalog.
|
Connection |
getConnection()
Retrieves the connection that produced this metadata object.
|
ResultSet |
getCrossReference(String primaryCatalog,
String primarySchema,
String primaryTable,
String foreignCatalog,
String foreignSchema,
String foreignTable)
Retrieves a description of the foreign key columns in the given foreign key
table that reference the primary key or the columns representing a unique constraint of the parent table (could be the same or a different table).
|
int |
getDatabaseMajorVersion()
Retrieves the major version number of the underlying database.
|
int |
getDatabaseMinorVersion()
Retrieves the minor version number of the underlying database.
|
String |
getDatabaseProductName()
Retrieves the name of this database product.
|
String |
getDatabaseProductVersion()
Retrieves the version number of this database product.
|
int |
getDefaultTransactionIsolation()
Retrieves this database's default transaction isolation level.
|
int |
getDriverMajorVersion()
Retrieves this JDBC driver's major version number.
|
int |
getDriverMinorVersion()
Retrieves this JDBC driver's minor version number.
|
String |
getDriverName()
Retrieves the name of this JDBC driver.
|
String |
getDriverVersion()
Retrieves the version number of this JDBC driver as a
String. |
ResultSet |
getExportedKeys(String catalog,
String schema,
String table)
Retrieves a description of the foreign key columns that reference the
given table's primary key columns (the foreign keys exported by a
table).
|
String |
getExtraNameCharacters()
Retrieves all the "extra" characters that can be used in unquoted
identifier names (those beyond a-z, A-Z, 0-9 and _).
|
ResultSet |
getFunctionColumns(String catalog,
String schemaPattern,
String functionNamePattern,
String columnNamePattern)
Retrieves a description of the given catalog's system or user
function parameters and return type.
|
ResultSet |
getFunctions(String catalog,
String schemaPattern,
String functionNamePattern)
Retrieves a description of the system and user functions available
in the given catalog.
|
String |
getIdentifierQuoteString()
What is the string used to quote SQL identifiers?
|
protected ResultSet |
getImportedExportedKeys(String primaryCatalog,
String primarySchema,
String primaryTable,
String foreignCatalog,
String foreignSchema,
String foreignTable) |
ResultSet |
getImportedKeys(String catalog,
String schema,
String table)
Retrieves a description of the primary key columns that are
referenced by the given table's foreign key columns (the primary keys
imported by a table).
|
ResultSet |
getIndexInfo(String catalog,
String schema,
String tableName,
boolean unique,
boolean approximate)
Retrieves a description of the given table's indices and statistics.
|
int |
getJDBCMajorVersion()
Retrieves the major JDBC version number for this
driver.
|
int |
getJDBCMinorVersion()
Retrieves the minor JDBC version number for this
driver.
|
int |
getMaxBinaryLiteralLength()
Retrieves the maximum number of hex characters this database allows in an
inline binary literal.
|
int |
getMaxCatalogNameLength()
Retrieves the maximum number of characters that this database allows in a
catalog name.
|
int |
getMaxCharLiteralLength()
Retrieves the maximum number of characters this database allows
for a character literal.
|
int |
getMaxColumnNameLength()
Retrieves the maximum number of characters this database allows
for a column name.
|
int |
getMaxColumnsInGroupBy()
Retrieves the maximum number of columns this database allows in a
GROUP BY clause. |
int |
getMaxColumnsInIndex()
Retrieves the maximum number of columns this database allows in an index.
|
int |
getMaxColumnsInOrderBy()
Retrieves the maximum number of columns this database allows in an
ORDER BY clause. |
int |
getMaxColumnsInSelect()
Retrieves the maximum number of columns this database allows in a
SELECT list. |
int |
getMaxColumnsInTable()
Retrieves the maximum number of columns this database allows in a table.
|
int |
getMaxConnections()
Retrieves the maximum number of concurrent connections to this
database that are possible.
|
int |
getMaxCursorNameLength()
Retrieves the maximum number of characters that this database allows in a
cursor name.
|
protected int |
getMaxIndexKeys() |
int |
getMaxIndexLength()
Retrieves the maximum number of bytes this database allows for an
index, including all of the parts of the index.
|
long |
getMaxLogicalLobSize() |
protected int |
getMaxNameLength() |
int |
getMaxProcedureNameLength()
Retrieves the maximum number of characters that this database allows in a
procedure name.
|
int |
getMaxRowSize()
Retrieves the maximum number of bytes this database allows in
a single row.
|
int |
getMaxSchemaNameLength()
Retrieves the maximum number of characters that this database allows in a
schema name.
|
int |
getMaxStatementLength()
Retrieves the maximum number of characters this database allows in
an SQL statement.
|
int |
getMaxStatements()
Retrieves the maximum number of active statements to this database
that can be open at the same time.
|
int |
getMaxTableNameLength()
Retrieves the maximum number of characters this database allows in
a table name.
|
int |
getMaxTablesInSelect()
Retrieves the maximum number of tables this database allows in a
SELECT statement. |
int |
getMaxUserNameLength()
Retrieves the maximum number of characters this database allows in
a user name.
|
String |
getNumericFunctions()
Retrieves a comma-separated list of math functions available with
this database.
|
ResultSet |
getPrimaryKeys(String catalog,
String schema,
String table)
Retrieves a description of the given table's primary key columns.
|
ResultSet |
getProcedureColumns(String catalog,
String schemaPattern,
String procedureNamePattern,
String columnNamePattern)
Retrieves a description of the given catalog's stored procedure parameter
and result columns.
|
ResultSet |
getProcedures(String catalog,
String schemaPattern,
String procedureNamePattern)
Retrieves a description of the stored procedures available in the given
catalog.
|
String |
getProcedureTerm()
Retrieves the database vendor's preferred term for "procedure".
|
ResultSet |
getPseudoColumns(String catalog,
String schemaPattern,
String tableNamePattern,
String columnNamePattern)
Retrieves a description of the pseudo or hidden columns available
in a given table within the specified catalog and schema.
|
int |
getResultSetHoldability()
Retrieves this database's default holdability for
ResultSet
objects. |
RowIdLifetime |
getRowIdLifetime()
Indicates whether or not this data source supports the SQL
ROWID type,
and if so the lifetime for which a RowId object remains valid. |
ResultSet |
getSchemas()
Retrieves the schema names available in this database.
|
ResultSet |
getSchemas(String catalog,
String schemaPattern)
Retrieves the schema names available in this database.
|
String |
getSchemaTerm()
Retrieves the database vendor's preferred term for "schema".
|
String |
getSearchStringEscape()
Retrieves the string that can be used to escape wildcard characters.
|
String |
getSQLKeywords()
Retrieves a comma-separated list of all of this database's SQL keywords
that are NOT also SQL:2003 keywords.
|
int |
getSQLStateType()
Indicates whether the SQLSTATE returned by
SQLException.getSQLState
is X/Open (now known as Open Group) SQL CLI or SQL:2003. |
String |
getStringFunctions()
Retrieves a comma-separated list of string functions available with
this database.
|
ResultSet |
getSuperTables(String catalog,
String schemaPattern,
String tableNamePattern)
Retrieves a description of the table hierarchies defined in a particular
schema in this database.
|
ResultSet |
getSuperTypes(String catalog,
String schemaPattern,
String typeNamePattern)
Retrieves a description of the user-defined type (UDT) hierarchies defined in a
particular schema in this database.
|
String |
getSystemFunctions()
Retrieves a comma-separated list of system functions available with
this database.
|
ResultSet |
getTablePrivileges(String catalog,
String schemaPattern,
String tableNamePattern)
Retrieves a description of the access rights for each table available
in a catalog.
|
ResultSet |
getTables(String catalog,
String schemaPattern,
String tableNamePattern,
String[] types)
Retrieves a description of the tables available in the given catalog.
|
ResultSet |
getTableTypes()
Retrieves the table types available in this database.
|
String |
getTimeDateFunctions()
Retrieves a comma-separated list of the time and date functions available
with this database.
|
ResultSet |
getTypeInfo()
Retrieves a description of all the data types supported by
this database.
|
ResultSet |
getUDTs(String catalog,
String schemaPattern,
String typeNamePattern,
int[] types)
Retrieves a description of the user-defined types (UDTs) defined
in a particular schema.
|
String |
getURL()
Retrieves the URL for this DBMS.
|
String |
getUserName()
Retrieves the user name as known to this database.
|
ResultSet |
getVersionColumns(String catalog,
String schema,
String table)
Retrieves a description of a table's columns that are automatically
updated when any value in a row is updated.
|
boolean |
insertsAreDetected(int type)
Retrieves whether or not a visible row insert can be detected
by calling the method
ResultSet.rowInserted. |
boolean |
isCatalogAtStart()
Retrieves whether a catalog appears at the start of a fully qualified
table name.
|
boolean |
isReadOnly()
Retrieves whether this database is in read-only mode.
|
boolean |
isWrapperFor(Class<?> iface)
Returns true if this either implements the interface argument or is directly or indirectly a wrapper
for an object that does.
|
boolean |
locatorsUpdateCopy()
Indicates whether updates made to a LOB are made on a copy or directly
to the LOB.
|
boolean |
nullPlusNonNullIsNull()
Retrieves whether this database supports concatenations between
NULL and non-NULL values being
NULL. |
boolean |
nullsAreSortedAtEnd()
Retrieves whether
NULL values are sorted at the end regardless of
sort order. |
boolean |
nullsAreSortedAtStart()
Retrieves whether
NULL values are sorted at the start regardless
of sort order. |
boolean |
nullsAreSortedHigh()
Retrieves whether
NULL values are sorted high. |
boolean |
nullsAreSortedLow()
Retrieves whether
NULL values are sorted low. |
boolean |
othersDeletesAreVisible(int i)
Retrieves whether deletes made by others are visible.
|
boolean |
othersInsertsAreVisible(int type)
Retrieves whether inserts made by others are visible.
|
boolean |
othersUpdatesAreVisible(int type)
Retrieves whether updates made by others are visible.
|
boolean |
ownDeletesAreVisible(int type)
Retrieves whether a result set's own deletes are visible.
|
boolean |
ownInsertsAreVisible(int type)
Retrieves whether a result set's own inserts are visible.
|
boolean |
ownUpdatesAreVisible(int type)
Retrieves whether for the given type of
ResultSet object,
the result set's own updates are visible. |
Map<String,Map<String,List<String[]>>> |
parseACL(String aclArray,
String owner)
Take the a String representing an array of ACLs and return a Map mapping the SQL permission
name to a List of usernames who have that permission.
|
boolean |
storesLowerCaseIdentifiers()
Retrieves whether this database treats mixed case unquoted SQL identifiers as
case insensitive and stores them in lower case.
|
boolean |
storesLowerCaseQuotedIdentifiers()
Retrieves whether this database treats mixed case quoted SQL identifiers as
case insensitive and stores them in lower case.
|
boolean |
storesMixedCaseIdentifiers()
Retrieves whether this database treats mixed case unquoted SQL identifiers as
case insensitive and stores them in mixed case.
|
boolean |
storesMixedCaseQuotedIdentifiers()
Retrieves whether this database treats mixed case quoted SQL identifiers as
case insensitive and stores them in mixed case.
|
boolean |
storesUpperCaseIdentifiers()
Retrieves whether this database treats mixed case unquoted SQL identifiers as
case insensitive and stores them in upper case.
|
boolean |
storesUpperCaseQuotedIdentifiers()
Retrieves whether this database treats mixed case quoted SQL identifiers as
case insensitive and stores them in upper case.
|
boolean |
supportsAlterTableWithAddColumn()
Retrieves whether this database supports
ALTER TABLE
with add column. |
boolean |
supportsAlterTableWithDropColumn()
Retrieves whether this database supports
ALTER TABLE
with drop column. |
boolean |
supportsANSI92EntryLevelSQL()
Does this driver support the ANSI-92 entry level SQL grammar?
|
boolean |
supportsANSI92FullSQL()
Retrieves whether this database supports the ANSI92 full SQL grammar supported.
|
boolean |
supportsANSI92IntermediateSQL()
Retrieves whether this database supports the ANSI92 intermediate SQL grammar supported.
|
boolean |
supportsBatchUpdates()
Retrieves whether this database supports batch updates.
|
boolean |
supportsCatalogsInDataManipulation()
Retrieves whether a catalog name can be used in a data manipulation statement.
|
boolean |
supportsCatalogsInIndexDefinitions()
Retrieves whether a catalog name can be used in an index definition statement.
|
boolean |
supportsCatalogsInPrivilegeDefinitions()
Retrieves whether a catalog name can be used in a privilege definition statement.
|
boolean |
supportsCatalogsInProcedureCalls()
Retrieves whether a catalog name can be used in a procedure call statement.
|
boolean |
supportsCatalogsInTableDefinitions()
Retrieves whether a catalog name can be used in a table definition statement.
|
boolean |
supportsColumnAliasing()
Retrieves whether this database supports column aliasing.
|
boolean |
supportsConvert()
Retrieves whether this database supports the JDBC scalar function
CONVERT for the conversion of one JDBC type to another. |
boolean |
supportsConvert(int fromType,
int toType)
Retrieves whether this database supports the JDBC scalar function
CONVERT for conversions between the JDBC types fromType
and toType. |
boolean |
supportsCoreSQLGrammar()
Does this driver support the Core ODBC SQL grammar.
|
boolean |
supportsCorrelatedSubqueries()
Retrieves whether this database supports correlated subqueries.
|
boolean |
supportsDataDefinitionAndDataManipulationTransactions()
Retrieves whether this database supports both data definition and
data manipulation statements within a transaction.
|
boolean |
supportsDataManipulationTransactionsOnly()
Retrieves whether this database supports only data manipulation
statements within a transaction.
|
boolean |
supportsDifferentTableCorrelationNames()
Retrieves whether, when table correlation names are supported, they
are restricted to being different from the names of the tables.
|
boolean |
supportsExpressionsInOrderBy()
Retrieves whether this database supports expressions in
ORDER BY lists. |
boolean |
supportsExtendedSQLGrammar()
Does this driver support the Extended (Level 2) ODBC SQL grammar.
|
boolean |
supportsFullOuterJoins()
Retrieves whether this database supports full nested outer joins.
|
boolean |
supportsGetGeneratedKeys()
Retrieves whether auto-generated keys can be retrieved after
a statement has been executed
|
boolean |
supportsGroupBy()
Retrieves whether this database supports some form of
GROUP BY clause. |
boolean |
supportsGroupByBeyondSelect()
Retrieves whether this database supports using columns not included in
the
SELECT statement in a GROUP BY clause
provided that all of the columns in the SELECT statement
are included in the GROUP BY clause. |
boolean |
supportsGroupByUnrelated()
Retrieves whether this database supports using a column that is
not in the
SELECT statement in a
GROUP BY clause. |
boolean |
supportsIntegrityEnhancementFacility()
Retrieves whether this database supports the SQL Integrity
Enhancement Facility.
|
boolean |
supportsLikeEscapeClause()
Retrieves whether this database supports specifying a
LIKE escape clause. |
boolean |
supportsLimitedOuterJoins()
Retrieves whether this database provides limited support for outer
joins.
|
boolean |
supportsMinimumSQLGrammar()
Retrieves whether this database supports the ODBC Minimum SQL grammar.
|
boolean |
supportsMixedCaseIdentifiers()
Does the database treat mixed case unquoted SQL identifiers as case sensitive and as a result
store them in mixed case?
|
boolean |
supportsMixedCaseQuotedIdentifiers()
Does the database treat mixed case quoted SQL identifiers as case sensitive and as a result
store them in mixed case?
|
boolean |
supportsMultipleOpenResults()
Retrieves whether it is possible to have multiple
ResultSet objects
returned from a CallableStatement object
simultaneously. |
boolean |
supportsMultipleResultSets()
Retrieves whether this database supports getting multiple
ResultSet objects from a single call to the
method execute. |
boolean |
supportsMultipleTransactions()
Retrieves whether this database allows having multiple
transactions open at once (on different connections).
|
boolean |
supportsNamedParameters()
Retrieves whether this database supports named parameters to callable
statements.
|
boolean |
supportsNonNullableColumns()
Retrieves whether columns in this database may be defined as non-nullable.
|
boolean |
supportsOpenCursorsAcrossCommit()
Retrieves whether this database supports keeping cursors open
across commits.
|
boolean |
supportsOpenCursorsAcrossRollback()
Retrieves whether this database supports keeping cursors open
across rollbacks.
|
boolean |
supportsOpenStatementsAcrossCommit()
Retrieves whether this database supports keeping statements open
across commits.
|
boolean |
supportsOpenStatementsAcrossRollback()
Retrieves whether this database supports keeping statements open
across rollbacks.
|
boolean |
supportsOrderByUnrelated()
Retrieves whether this database supports using a column that is
not in the
SELECT statement in an
ORDER BY clause. |
boolean |
supportsOuterJoins()
Retrieves whether this database supports some form of outer join.
|
boolean |
supportsPositionedDelete()
We support cursors for gets only it seems.
|
boolean |
supportsPositionedUpdate()
Retrieves whether this database supports positioned
UPDATE
statements. |
boolean |
supportsRefCursors() |
boolean |
supportsResultSetConcurrency(int type,
int concurrency)
Retrieves whether this database supports the given concurrency type
in combination with the given result set type.
|
boolean |
supportsResultSetHoldability(int holdability)
Retrieves whether this database supports the given result set holdability.
|
boolean |
supportsResultSetType(int type)
Retrieves whether this database supports the given result set type.
|
boolean |
supportsSavepoints()
Retrieves whether this database supports savepoints.
|
boolean |
supportsSchemasInDataManipulation()
Retrieves whether a schema name can be used in a data manipulation statement.
|
boolean |
supportsSchemasInIndexDefinitions()
Retrieves whether a schema name can be used in an index definition statement.
|
boolean |
supportsSchemasInPrivilegeDefinitions()
Retrieves whether a schema name can be used in a privilege definition statement.
|
boolean |
supportsSchemasInProcedureCalls()
Retrieves whether a schema name can be used in a procedure call statement.
|
boolean |
supportsSchemasInTableDefinitions()
Retrieves whether a schema name can be used in a table definition statement.
|
boolean |
supportsSelectForUpdate()
Retrieves whether this database supports
SELECT FOR UPDATE
statements. |
boolean |
supportsStatementPooling()
Retrieves whether this database supports statement pooling.
|
boolean |
supportsStoredFunctionsUsingCallSyntax()
Retrieves whether this database supports invoking user-defined or vendor functions
using the stored procedure escape syntax.
|
boolean |
supportsStoredProcedures()
Retrieves whether this database supports stored procedure calls
that use the stored procedure escape syntax.
|
boolean |
supportsSubqueriesInComparisons()
Retrieves whether this database supports subqueries in comparison
expressions.
|
boolean |
supportsSubqueriesInExists()
Retrieves whether this database supports subqueries in
EXISTS expressions. |
boolean |
supportsSubqueriesInIns()
Retrieves whether this database supports subqueries in
IN expressions. |
boolean |
supportsSubqueriesInQuantifieds()
Retrieves whether this database supports subqueries in quantified
expressions.
|
boolean |
supportsTableCorrelationNames()
Retrieves whether this database supports table correlation names.
|
boolean |
supportsTransactionIsolationLevel(int level)
Retrieves whether this database supports the given transaction isolation level.
|
boolean |
supportsTransactions()
Retrieves whether this database supports transactions.
|
boolean |
supportsUnion()
Retrieves whether this database supports SQL
UNION. |
boolean |
supportsUnionAll()
Retrieves whether this database supports SQL
UNION ALL. |
<T> T |
unwrap(Class<T> iface)
Returns an object that implements the given interface to allow access to
non-standard methods, or standard methods not exposed by the proxy.
|
boolean |
updatesAreDetected(int type)
Retrieves whether or not a visible row update can be detected by
calling the method
ResultSet.rowUpdated. |
boolean |
usesLocalFilePerTable()
Does the database use a file for each table?
|
boolean |
usesLocalFiles()
Does the database store tables in a local file?
|
protected final PgConnection connection
public PgDatabaseMetaData(PgConnection conn)
protected int getMaxIndexKeys()
throws SQLException
SQLExceptionprotected int getMaxNameLength()
throws SQLException
SQLExceptionpublic boolean allProceduresAreCallable()
throws SQLException
java.sql.DatabaseMetaDatagetProcedures.allProceduresAreCallable in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean allTablesAreSelectable()
throws SQLException
java.sql.DatabaseMetaDatagetTables in a SELECT
statement.allTablesAreSelectable in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic String getURL() throws SQLException
java.sql.DatabaseMetaDatagetURL in interface DatabaseMetaDatanull if it cannot be
generatedSQLException - if a database access error occurspublic String getUserName() throws SQLException
java.sql.DatabaseMetaDatagetUserName in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean isReadOnly()
throws SQLException
java.sql.DatabaseMetaDataisReadOnly in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean nullsAreSortedHigh()
throws SQLException
java.sql.DatabaseMetaDataNULL values are sorted high.
Sorted high means that NULL values
sort higher than any other value in a domain. In an ascending order,
if this method returns true, NULL values
will appear at the end. By contrast, the method
nullsAreSortedAtEnd indicates whether NULL values
are sorted at the end regardless of sort order.nullsAreSortedHigh in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean nullsAreSortedLow()
throws SQLException
java.sql.DatabaseMetaDataNULL values are sorted low.
Sorted low means that NULL values
sort lower than any other value in a domain. In an ascending order,
if this method returns true, NULL values
will appear at the beginning. By contrast, the method
nullsAreSortedAtStart indicates whether NULL values
are sorted at the beginning regardless of sort order.nullsAreSortedLow in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean nullsAreSortedAtStart()
throws SQLException
java.sql.DatabaseMetaDataNULL values are sorted at the start regardless
of sort order.nullsAreSortedAtStart in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean nullsAreSortedAtEnd()
throws SQLException
java.sql.DatabaseMetaDataNULL values are sorted at the end regardless of
sort order.nullsAreSortedAtEnd in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic String getDatabaseProductName() throws SQLException
getDatabaseProductName in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getDatabaseProductVersion() throws SQLException
java.sql.DatabaseMetaDatagetDatabaseProductVersion in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getDriverName()
java.sql.DatabaseMetaDatagetDriverName in interface DatabaseMetaDatapublic String getDriverVersion()
java.sql.DatabaseMetaDataString.getDriverVersion in interface DatabaseMetaDatapublic int getDriverMajorVersion()
java.sql.DatabaseMetaDatagetDriverMajorVersion in interface DatabaseMetaDatapublic int getDriverMinorVersion()
java.sql.DatabaseMetaDatagetDriverMinorVersion in interface DatabaseMetaDatapublic boolean usesLocalFiles()
throws SQLException
usesLocalFiles in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean usesLocalFilePerTable()
throws SQLException
usesLocalFilePerTable in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsMixedCaseIdentifiers()
throws SQLException
supportsMixedCaseIdentifiers in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean storesUpperCaseIdentifiers()
throws SQLException
java.sql.DatabaseMetaDatastoresUpperCaseIdentifiers in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean storesLowerCaseIdentifiers()
throws SQLException
java.sql.DatabaseMetaDatastoresLowerCaseIdentifiers in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean storesMixedCaseIdentifiers()
throws SQLException
java.sql.DatabaseMetaDatastoresMixedCaseIdentifiers in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsMixedCaseQuotedIdentifiers()
throws SQLException
supportsMixedCaseQuotedIdentifiers in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean storesUpperCaseQuotedIdentifiers()
throws SQLException
java.sql.DatabaseMetaDatastoresUpperCaseQuotedIdentifiers in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean storesLowerCaseQuotedIdentifiers()
throws SQLException
java.sql.DatabaseMetaDatastoresLowerCaseQuotedIdentifiers in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean storesMixedCaseQuotedIdentifiers()
throws SQLException
java.sql.DatabaseMetaDatastoresMixedCaseQuotedIdentifiers in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic String getIdentifierQuoteString() throws SQLException
getIdentifierQuoteString in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getSQLKeywords() throws SQLException
Within PostgreSQL, the keywords are found in src/backend/parser/keywords.c
For SQL Keywords, I took the list provided at http://web.dementia.org/~ shadow/sql/sql3bnf.sep93.txt which is for SQL3, not SQL-92, but it is close enough for this purpose.
getSQLKeywords in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getNumericFunctions() throws SQLException
java.sql.DatabaseMetaDatagetNumericFunctions in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getStringFunctions() throws SQLException
java.sql.DatabaseMetaDatagetStringFunctions in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getSystemFunctions() throws SQLException
java.sql.DatabaseMetaDatagetSystemFunctions in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getTimeDateFunctions() throws SQLException
java.sql.DatabaseMetaDatagetTimeDateFunctions in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getSearchStringEscape() throws SQLException
java.sql.DatabaseMetaDataThe '_' character represents any single character; the '%' character represents any sequence of zero or more characters.
getSearchStringEscape in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getExtraNameCharacters() throws SQLException
Postgresql allows any high-bit character to be used in an unquoted identifier, so we can't possibly list them all. From the file src/backend/parser/scan.l, an identifier is ident_start [A-Za-z\200-\377_] ident_cont [A-Za-z\200-\377_0-9\$] identifier {ident_start}{ident_cont}*
getExtraNameCharacters in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsAlterTableWithAddColumn()
throws SQLException
ALTER TABLE
with add column.supportsAlterTableWithAddColumn in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsAlterTableWithDropColumn()
throws SQLException
ALTER TABLE
with drop column.supportsAlterTableWithDropColumn in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsColumnAliasing()
throws SQLException
java.sql.DatabaseMetaDataIf so, the SQL AS clause can be used to provide names for computed columns or to provide alias names for columns as required.
supportsColumnAliasing in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean nullPlusNonNullIsNull()
throws SQLException
java.sql.DatabaseMetaDataNULL and non-NULL values being
NULL.nullPlusNonNullIsNull in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsConvert()
throws SQLException
java.sql.DatabaseMetaDataCONVERT for the conversion of one JDBC type to another.
The JDBC types are the generic SQL data types defined
in java.sql.Types.supportsConvert in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsConvert(int fromType,
int toType)
throws SQLException
java.sql.DatabaseMetaDataCONVERT for conversions between the JDBC types fromType
and toType. The JDBC types are the generic SQL data types defined
in java.sql.Types.supportsConvert in interface DatabaseMetaDatafromType - the type to convert from; one of the type codes from
the class java.sql.TypestoType - the type to convert to; one of the type codes from
the class java.sql.Typestrue if so; false otherwiseSQLException - if a database access error occursTypespublic boolean supportsTableCorrelationNames()
throws SQLException
java.sql.DatabaseMetaDatasupportsTableCorrelationNames in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsDifferentTableCorrelationNames()
throws SQLException
java.sql.DatabaseMetaDatasupportsDifferentTableCorrelationNames in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsExpressionsInOrderBy()
throws SQLException
java.sql.DatabaseMetaDataORDER BY lists.supportsExpressionsInOrderBy in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsOrderByUnrelated()
throws SQLException
SELECT statement in an
ORDER BY clause.supportsOrderByUnrelated in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsGroupBy()
throws SQLException
java.sql.DatabaseMetaDataGROUP BY clause.supportsGroupBy in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsGroupByUnrelated()
throws SQLException
SELECT statement in a
GROUP BY clause.supportsGroupByUnrelated in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsGroupByBeyondSelect()
throws SQLException
java.sql.DatabaseMetaDataSELECT statement in a GROUP BY clause
provided that all of the columns in the SELECT statement
are included in the GROUP BY clause.supportsGroupByBeyondSelect in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsLikeEscapeClause()
throws SQLException
java.sql.DatabaseMetaDataLIKE escape clause.supportsLikeEscapeClause in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsMultipleResultSets()
throws SQLException
java.sql.DatabaseMetaDataResultSet objects from a single call to the
method execute.supportsMultipleResultSets in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsMultipleTransactions()
throws SQLException
java.sql.DatabaseMetaDatasupportsMultipleTransactions in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsNonNullableColumns()
throws SQLException
java.sql.DatabaseMetaDatasupportsNonNullableColumns in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsMinimumSQLGrammar()
throws SQLException
http://www. microsoft.com/msdn/sdk/platforms/doc/odbc/src/intropr.htm
In Appendix C. From this description, we seem to support the ODBC minimal (Level 0) grammar.
supportsMinimumSQLGrammar in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsCoreSQLGrammar()
throws SQLException
supportsCoreSQLGrammar in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsExtendedSQLGrammar()
throws SQLException
supportsExtendedSQLGrammar in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsANSI92EntryLevelSQL()
throws SQLException
supportsANSI92EntryLevelSQL in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsANSI92IntermediateSQL()
throws SQLException
supportsANSI92IntermediateSQL in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsANSI92FullSQL()
throws SQLException
supportsANSI92FullSQL in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsIntegrityEnhancementFacility()
throws SQLException
java.sql.DatabaseMetaDatasupportsIntegrityEnhancementFacility in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsOuterJoins()
throws SQLException
supportsOuterJoins in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsFullOuterJoins()
throws SQLException
supportsFullOuterJoins in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsLimitedOuterJoins()
throws SQLException
true if the method
supportsFullOuterJoins returns true).supportsLimitedOuterJoins in interface DatabaseMetaDataSQLException - if a database access error occurspublic String getSchemaTerm() throws SQLException
PostgreSQL doesn't have schemas, but when it does, we'll use the term "schema".
getSchemaTerm in interface DatabaseMetaData"schema"SQLException - if a database access error occurspublic String getProcedureTerm() throws SQLException
getProcedureTerm in interface DatabaseMetaData"function"SQLException - if a database access error occurspublic String getCatalogTerm() throws SQLException
getCatalogTerm in interface DatabaseMetaData"database"SQLException - if a database access error occurspublic boolean isCatalogAtStart()
throws SQLException
java.sql.DatabaseMetaDataisCatalogAtStart in interface DatabaseMetaDatatrue if the catalog name appears at the beginning
of a fully qualified table name; false otherwiseSQLException - if a database access error occurspublic String getCatalogSeparator() throws SQLException
java.sql.DatabaseMetaDataString that this database uses as the
separator between a catalog and table name.getCatalogSeparator in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsSchemasInDataManipulation()
throws SQLException
supportsSchemasInDataManipulation in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsSchemasInProcedureCalls()
throws SQLException
supportsSchemasInProcedureCalls in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsSchemasInTableDefinitions()
throws SQLException
supportsSchemasInTableDefinitions in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsSchemasInIndexDefinitions()
throws SQLException
supportsSchemasInIndexDefinitions in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsSchemasInPrivilegeDefinitions()
throws SQLException
supportsSchemasInPrivilegeDefinitions in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsCatalogsInDataManipulation()
throws SQLException
java.sql.DatabaseMetaDatasupportsCatalogsInDataManipulation in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsCatalogsInProcedureCalls()
throws SQLException
java.sql.DatabaseMetaDatasupportsCatalogsInProcedureCalls in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsCatalogsInTableDefinitions()
throws SQLException
java.sql.DatabaseMetaDatasupportsCatalogsInTableDefinitions in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsCatalogsInIndexDefinitions()
throws SQLException
java.sql.DatabaseMetaDatasupportsCatalogsInIndexDefinitions in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsCatalogsInPrivilegeDefinitions()
throws SQLException
java.sql.DatabaseMetaDatasupportsCatalogsInPrivilegeDefinitions in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsPositionedDelete()
throws SQLException
supportsPositionedDelete in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsPositionedUpdate()
throws SQLException
java.sql.DatabaseMetaDataUPDATE
statements.supportsPositionedUpdate in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsSelectForUpdate()
throws SQLException
SELECT FOR UPDATE
statements.supportsSelectForUpdate in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsStoredProcedures()
throws SQLException
java.sql.DatabaseMetaDatasupportsStoredProcedures in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsSubqueriesInComparisons()
throws SQLException
java.sql.DatabaseMetaDatasupportsSubqueriesInComparisons in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsSubqueriesInExists()
throws SQLException
java.sql.DatabaseMetaDataEXISTS expressions.supportsSubqueriesInExists in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsSubqueriesInIns()
throws SQLException
java.sql.DatabaseMetaDataIN expressions.supportsSubqueriesInIns in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsSubqueriesInQuantifieds()
throws SQLException
java.sql.DatabaseMetaDatasupportsSubqueriesInQuantifieds in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsCorrelatedSubqueries()
throws SQLException
supportsCorrelatedSubqueries in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsUnion()
throws SQLException
UNION.supportsUnion in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsUnionAll()
throws SQLException
UNION ALL.supportsUnionAll in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsOpenCursorsAcrossCommit()
throws SQLException
supportsOpenCursorsAcrossCommit in interface DatabaseMetaDatatrue if cursors always remain open;
false if they might not remain openSQLException - if a database access error occurspublic boolean supportsOpenCursorsAcrossRollback()
throws SQLException
java.sql.DatabaseMetaDatasupportsOpenCursorsAcrossRollback in interface DatabaseMetaDatatrue if cursors always remain open;
false if they might not remain openSQLException - if a database access error occurspublic boolean supportsOpenStatementsAcrossCommit()
throws SQLException
Can statements remain open across commits? They may, but this driver cannot guarantee that. In further reflection. we are talking a Statement object here, so the answer is yes, since the Statement is only a vehicle to ExecSQL()
supportsOpenStatementsAcrossCommit in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean supportsOpenStatementsAcrossRollback()
throws SQLException
Can statements remain open across rollbacks? They may, but this driver cannot guarantee that. In further contemplation, we are talking a Statement object here, so the answer is yes, since the Statement is only a vehicle to ExecSQL() in Connection
supportsOpenStatementsAcrossRollback in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxCharLiteralLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxCharLiteralLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxBinaryLiteralLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxBinaryLiteralLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxColumnNameLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxColumnNameLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxColumnsInGroupBy()
throws SQLException
java.sql.DatabaseMetaDataGROUP BY clause.getMaxColumnsInGroupBy in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxColumnsInIndex()
throws SQLException
java.sql.DatabaseMetaDatagetMaxColumnsInIndex in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxColumnsInOrderBy()
throws SQLException
java.sql.DatabaseMetaDataORDER BY clause.getMaxColumnsInOrderBy in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxColumnsInSelect()
throws SQLException
java.sql.DatabaseMetaDataSELECT list.getMaxColumnsInSelect in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxColumnsInTable()
throws SQLException
"The new class is created as a heap with no initial data. A class can have no more than 1600 attributes (realistically, this is limited by the fact that tuple sizes must be less than 8192 bytes)..."
getMaxColumnsInTable in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxConnections()
throws SQLException
getMaxConnections in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxCursorNameLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxCursorNameLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxIndexLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxIndexLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxSchemaNameLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxSchemaNameLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxProcedureNameLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxProcedureNameLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxCatalogNameLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxCatalogNameLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxRowSize()
throws SQLException
java.sql.DatabaseMetaDatagetMaxRowSize in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean doesMaxRowSizeIncludeBlobs()
throws SQLException
java.sql.DatabaseMetaDatagetMaxRowSize includes the SQL data types
LONGVARCHAR and LONGVARBINARY.doesMaxRowSizeIncludeBlobs in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic int getMaxStatementLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxStatementLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxStatements()
throws SQLException
java.sql.DatabaseMetaDatagetMaxStatements in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxTableNameLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxTableNameLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getMaxTablesInSelect()
throws SQLException
java.sql.DatabaseMetaDataSELECT statement.getMaxTablesInSelect in interface DatabaseMetaDataSELECT
statement; a result of zero means that there is no limit or
the limit is not knownSQLException - if a database access error occurspublic int getMaxUserNameLength()
throws SQLException
java.sql.DatabaseMetaDatagetMaxUserNameLength in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getDefaultTransactionIsolation()
throws SQLException
java.sql.DatabaseMetaDatajava.sql.Connection.getDefaultTransactionIsolation in interface DatabaseMetaDataSQLException - if a database access error occursConnectionpublic boolean supportsTransactions()
throws SQLException
java.sql.DatabaseMetaDatacommit is a noop, and the isolation level is
TRANSACTION_NONE.supportsTransactions in interface DatabaseMetaDatatrue if transactions are supported;
false otherwiseSQLException - if a database access error occurspublic boolean supportsTransactionIsolationLevel(int level)
throws SQLException
We only support TRANSACTION_SERIALIZABLE and TRANSACTION_READ_COMMITTED before 8.0; from 8.0 READ_UNCOMMITTED and REPEATABLE_READ are accepted aliases for READ_COMMITTED.
supportsTransactionIsolationLevel in interface DatabaseMetaDatalevel - one of the transaction isolation levels defined in
java.sql.Connectiontrue if so; false otherwiseSQLException - if a database access error occursConnectionpublic boolean supportsDataDefinitionAndDataManipulationTransactions()
throws SQLException
java.sql.DatabaseMetaDatasupportsDataDefinitionAndDataManipulationTransactions in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsDataManipulationTransactionsOnly()
throws SQLException
java.sql.DatabaseMetaDatasupportsDataManipulationTransactionsOnly in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean dataDefinitionCausesTransactionCommit()
throws SQLException
CREATE TABLE T (A INT); INSERT INTO T (A) VALUES (2); BEGIN; UPDATE T SET A = A + 1; CREATE TABLE X (A INT); SELECT A FROM T INTO X; COMMIT;does the CREATE TABLE call cause a commit? The answer is no.
dataDefinitionCausesTransactionCommit in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean dataDefinitionIgnoredInTransactions()
throws SQLException
java.sql.DatabaseMetaDatadataDefinitionIgnoredInTransactions in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occursprotected String escapeQuotes(String s) throws SQLException
s - input valueSQLException - if something wrong happenspublic ResultSet getProcedures(String catalog, String schemaPattern, String procedureNamePattern) throws SQLException
java.sql.DatabaseMetaData
Only procedure descriptions matching the schema and
procedure name criteria are returned. They are ordered by
PROCEDURE_CAT, PROCEDURE_SCHEM,
PROCEDURE_NAME and SPECIFIC_ NAME.
Each procedure description has the the following columns:
null)
null)
A user may not have permissions to execute any of the procedures that are
returned by getProcedures
getProcedures in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchprocedureNamePattern - a procedure name pattern; must match the
procedure name as it is stored in the databaseResultSet - each row is a procedure descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getProcedureColumns(String catalog, String schemaPattern, String procedureNamePattern, String columnNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly 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 ResultSet is a parameter description or
column description with the following fields:
null)
null)
ResultSet
null)
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.
getProcedureColumns in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchprocedureNamePattern - a procedure name pattern; must match the
procedure name as it is stored in the databasecolumnNamePattern - a column name pattern; must match the column name
as it is stored in the databaseResultSet - each row describes a stored procedure parameter or
columnSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getTables(String catalog, String schemaPattern, String tableNamePattern, String[] types) throws SQLException
java.sql.DatabaseMetaDataTABLE_TYPE, TABLE_CAT,
TABLE_SCHEM and TABLE_NAME.
Each table description has the following columns:
null)
null)
null)
null)
null)
null)
null)
Note: Some databases may not return information for all tables.
getTables in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtableNamePattern - a table name pattern; must match the
table name as it is stored in the databasetypes - a list of table types, which must be from the list of table types
returned from DatabaseMetaData.getTableTypes(),to include; null returns
all typesResultSet - each row is a table descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getSchemas() throws SQLException
java.sql.DatabaseMetaDataTABLE_CATALOG and
TABLE_SCHEM.
The schema columns are:
null)
getSchemas in interface DatabaseMetaDataResultSet object in which each row is a
schema descriptionSQLException - if a database access error occurspublic ResultSet getSchemas(String catalog, String schemaPattern) throws SQLException
java.sql.DatabaseMetaDataTABLE_CATALOG and
TABLE_SCHEM.
The schema columns are:
null)
getSchemas in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it is stored
in the database;"" retrieves those without a catalog; null means catalog
name should not be used to narrow down the search.schemaPattern - a schema name; must match the schema name as it is
stored in the database; null means
schema name should not be used to narrow down the search.ResultSet object in which each row is a
schema descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getCatalogs() throws SQLException
The catalog column is:
getCatalogs in interface DatabaseMetaDataResultSet object in which each row has a
single String column that is a catalog nameSQLException - if a database access error occurspublic ResultSet getTableTypes() throws SQLException
java.sql.DatabaseMetaDataThe table type is:
getTableTypes in interface DatabaseMetaDataResultSet object in which each row has a
single String column that is a table typeSQLException - if a database access error occurspublic ResultSet getColumns(String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly column descriptions matching the catalog, schema, table
and column name criteria are returned. They are ordered by
TABLE_CAT,TABLE_SCHEM,
TABLE_NAME, and ORDINAL_POSITION.
Each column description has the following columns:
null)
null)
NULL values
NULL values
null)
null)
null if DATA_TYPE isn't REF)
null if the DATA_TYPE isn't REF)
null if the DATA_TYPE isn't REF)
null if DATA_TYPE
isn't DISTINCT or user-generated REF)
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.
getColumns in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtableNamePattern - a table name pattern; must match the
table name as it is stored in the databasecolumnNamePattern - a column name pattern; must match the column
name as it is stored in the databaseResultSet - each row is a column descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getColumnPrivileges(String catalog, String schema, String table, String columnNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly privileges matching the column name criteria are returned. They are ordered by COLUMN_NAME and PRIVILEGE.
Each privilige description has the following columns:
null)
null)
null)
null if unknown
getColumnPrivileges in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschema - a schema name; must match the schema name as it is
stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtable - a table name; must match the table name as it is
stored in the databasecolumnNamePattern - a column name pattern; must match the column
name as it is stored in the databaseResultSet - each row is a column privilege descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getTablePrivileges(String catalog, String schemaPattern, String tableNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly privileges matching the schema and table name
criteria are returned. They are ordered by
TABLE_CAT,
TABLE_SCHEM, TABLE_NAME,
and PRIVILEGE.
Each privilige description has the following columns:
null)
null)
null)
null if unknown
getTablePrivileges in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtableNamePattern - a table name pattern; must match the
table name as it is stored in the databaseResultSet - each row is a table privilege descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public Map<String,Map<String,List<String[]>>> parseACL(String aclArray, String owner)
SELECT -> user1 -> list of [grantor, grantable]aclArray - ACL arrayowner - ownerpublic ResultSet getBestRowIdentifier(String catalog, String schema, String table, int scope, boolean nullable) throws SQLException
java.sql.DatabaseMetaDataEach 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.
getBestRowIdentifier in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschema - a schema name; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtable - a table name; must match the table name as it is stored
in the databasescope - the scope of interest; use same values as SCOPEnullable - include columns that are nullable.ResultSet - each row is a column descriptionSQLException - if a database access error occurspublic ResultSet getVersionColumns(String catalog, String schema, String table) throws SQLException
java.sql.DatabaseMetaDataEach column description has the following columns:
java.sql.Types
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.
getVersionColumns in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschema - a schema name; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtable - a table name; must match the table name as it is stored
in the databaseResultSet object in which each row is a
column descriptionSQLException - if a database access error occurspublic ResultSet getPrimaryKeys(String catalog, String schema, String table) throws SQLException
java.sql.DatabaseMetaDataEach primary key column description has the following columns:
null)
null)
null)
getPrimaryKeys in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschema - a schema name; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtable - a table name; must match the table name as it is stored
in the databaseResultSet - each row is a primary key column descriptionSQLException - if a database access error occursprotected ResultSet getImportedExportedKeys(String primaryCatalog, String primarySchema, String primaryTable, String foreignCatalog, String foreignSchema, String foreignTable) throws SQLException
primaryCatalog - primary catalogprimarySchema - primary schemaprimaryTable - if provided will get the keys exported by this tableforeignCatalog - foreign catalogforeignSchema - foreign schemaforeignTable - if provided will get the keys imported by this tableSQLException - if something wrong happenspublic ResultSet getImportedKeys(String catalog, String schema, String table) throws SQLException
java.sql.DatabaseMetaDataEach primary key column description has the following columns:
null)
null)
null)
null)
NULL
if its primary key has been updated
null)
null)
getImportedKeys in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschema - a schema name; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtable - a table name; must match the table name as it is stored
in the databaseResultSet - each row is a primary key column descriptionSQLException - if a database access error occursDatabaseMetaData.getExportedKeys(java.lang.String, java.lang.String, java.lang.String)public ResultSet getExportedKeys(String catalog, String schema, String table) throws SQLException
java.sql.DatabaseMetaDataEach foreign key column description has the following columns:
null)
null)
null)
being exported (may be null)
null)
being exported (may be null)
NULL if
its primary key has been updated
NULL if
its primary key has been deleted
null)
null)
getExportedKeys in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in this database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschema - a schema name; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtable - a table name; must match the table name as it is stored
in this databaseResultSet object in which each row is a
foreign key column descriptionSQLException - if a database access error occursDatabaseMetaData.getImportedKeys(java.lang.String, java.lang.String, java.lang.String)public ResultSet getCrossReference(String primaryCatalog, String primarySchema, String primaryTable, String foreignCatalog, String foreignSchema, String foreignTable) throws SQLException
java.sql.DatabaseMetaDataEach foreign key column description has the following columns:
null)
null)
null)
being exported (may be null)
null)
being exported (may be null)
NULL if
its parent key has been updated
NULL if
its primary key has been deleted
null)
null)
getCrossReference in interface DatabaseMetaDataprimaryCatalog - a catalog name; must match the catalog name
as it is stored in the database; "" retrieves those without a
catalog; null means drop catalog name from the selection criteriaprimarySchema - a schema name; must match the schema name as
it is stored in the database; "" retrieves those without a schema;
null means drop schema name from the selection criteriaprimaryTable - the name of the table that exports the key; must match
the table name as it is stored in the databaseforeignCatalog - a catalog name; must match the catalog name as
it is stored in the database; "" retrieves those without a
catalog; null means drop catalog name from the selection criteriaforeignSchema - a schema name; must match the schema name as it
is stored in the database; "" retrieves those without a schema;
null means drop schema name from the selection criteriaforeignTable - the name of the table that imports the key; must match
the table name as it is stored in the databaseResultSet - each row is a foreign key column descriptionSQLException - if a database access error occursDatabaseMetaData.getImportedKeys(java.lang.String, java.lang.String, java.lang.String)public ResultSet getTypeInfo() throws SQLException
java.sql.DatabaseMetaDataIf 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:
null)
null)
null)
null)
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.
getTypeInfo in interface DatabaseMetaDataResultSet object in which each row is an SQL
type descriptionSQLException - if a database access error occurspublic ResultSet getIndexInfo(String catalog, String schema, String tableName, boolean unique, boolean approximate) throws SQLException
java.sql.DatabaseMetaDataEach index column description has the following columns:
null)
null)
null);
null when TYPE is tableIndexStatistic
null when TYPE is
tableIndexStatistic
null when TYPE is
tableIndexStatistic
null if sort sequence is not supported;
null when TYPE is tableIndexStatistic
null)
getIndexInfo in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in this database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschema - a schema name; must match the schema name
as it is stored in this database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtableName - a table name; must match the table name as it is stored
in this databaseunique - when true, return only indices for unique values;
when false, return indices regardless of whether unique or notapproximate - when true, result is allowed to reflect approximate
or out of data values; when false, results are requested to be
accurateResultSet - each row is an index column descriptionSQLException - if a database access error occurspublic boolean supportsResultSetType(int type)
throws SQLException
java.sql.DatabaseMetaDatasupportsResultSetType in interface DatabaseMetaDatatype - defined in java.sql.ResultSettrue if so; false otherwiseSQLException - if a database access error occursConnectionpublic boolean supportsResultSetConcurrency(int type,
int concurrency)
throws SQLException
java.sql.DatabaseMetaDatasupportsResultSetConcurrency in interface DatabaseMetaDatatype - defined in java.sql.ResultSetconcurrency - type defined in java.sql.ResultSettrue if so; false otherwiseSQLException - if a database access error occursConnectionpublic boolean ownUpdatesAreVisible(int type)
throws SQLException
java.sql.DatabaseMetaDataResultSet object,
the result set's own updates are visible.ownUpdatesAreVisible in interface DatabaseMetaDatatype - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if updates are visible for the given result set type;
false otherwiseSQLException - if a database access error occurspublic boolean ownDeletesAreVisible(int type)
throws SQLException
java.sql.DatabaseMetaDataownDeletesAreVisible in interface DatabaseMetaDatatype - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if deletes are visible for the given result set type;
false otherwiseSQLException - if a database access error occurspublic boolean ownInsertsAreVisible(int type)
throws SQLException
java.sql.DatabaseMetaDataownInsertsAreVisible in interface DatabaseMetaDatatype - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if inserts are visible for the given result set type;
false otherwiseSQLException - if a database access error occurspublic boolean othersUpdatesAreVisible(int type)
throws SQLException
java.sql.DatabaseMetaDataothersUpdatesAreVisible in interface DatabaseMetaDatatype - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if updates made by others
are visible for the given result set type;
false otherwiseSQLException - if a database access error occurspublic boolean othersDeletesAreVisible(int i)
throws SQLException
java.sql.DatabaseMetaDataothersDeletesAreVisible in interface DatabaseMetaDatai - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if deletes made by others
are visible for the given result set type;
false otherwiseSQLException - if a database access error occurspublic boolean othersInsertsAreVisible(int type)
throws SQLException
java.sql.DatabaseMetaDataothersInsertsAreVisible in interface DatabaseMetaDatatype - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if inserts made by others
are visible for the given result set type;
false otherwiseSQLException - if a database access error occurspublic boolean updatesAreDetected(int type)
throws SQLException
java.sql.DatabaseMetaDataResultSet.rowUpdated.updatesAreDetected in interface DatabaseMetaDatatype - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if changes are detected by the result set type;
false otherwiseSQLException - if a database access error occurspublic boolean deletesAreDetected(int i)
throws SQLException
java.sql.DatabaseMetaDataResultSet.rowDeleted. If the method
deletesAreDetected returns false, it means that
deleted rows are removed from the result set.deletesAreDetected in interface DatabaseMetaDatai - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if deletes are detected by the given result set type;
false otherwiseSQLException - if a database access error occurspublic boolean insertsAreDetected(int type)
throws SQLException
java.sql.DatabaseMetaDataResultSet.rowInserted.insertsAreDetected in interface DatabaseMetaDatatype - the ResultSet type; one of
ResultSet.TYPE_FORWARD_ONLY,
ResultSet.TYPE_SCROLL_INSENSITIVE, or
ResultSet.TYPE_SCROLL_SENSITIVEtrue if changes are detected by the specified result
set type; false otherwiseSQLException - if a database access error occurspublic boolean supportsBatchUpdates()
throws SQLException
java.sql.DatabaseMetaDatasupportsBatchUpdates in interface DatabaseMetaDatatrue if this database supports batch upcates;
false otherwiseSQLException - if a database access error occurspublic ResultSet getUDTs(String catalog, String schemaPattern, String typeNamePattern, int[] types) throws SQLException
java.sql.DatabaseMetaDataJAVA_OBJECT, STRUCT,
or DISTINCT.
Only types matching the catalog, schema, type name and type
criteria are returned. They are ordered by DATA_TYPE,
TYPE_CAT, TYPE_SCHEM and
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:
null)
null)
null if DATA_TYPE is not
DISTINCT or not STRUCT with REFERENCE_GENERATION = USER_DEFINED)
Note: If the driver does not support UDTs, an empty result set is returned.
getUDTs in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema pattern name; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtypeNamePattern - a type name pattern; must match the type name
as it is stored in the database; may be a fully qualified nametypes - a list of user-defined types (JAVA_OBJECT,
STRUCT, or DISTINCT) to include; null returns all typesResultSet object in which each row describes a UDTSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public Connection getConnection() throws SQLException
java.sql.DatabaseMetaDatagetConnection in interface DatabaseMetaDataSQLException - if a database access error occursprotected Statement createMetaDataStatement() throws SQLException
SQLExceptionpublic long getMaxLogicalLobSize()
throws SQLException
SQLExceptionpublic boolean supportsRefCursors()
throws SQLException
SQLExceptionpublic RowIdLifetime getRowIdLifetime() throws SQLException
java.sql.DatabaseMetaDataROWID type,
and if so the lifetime for which a RowId object remains valid.
The returned int values have the following relationship:
ROWID_UNSUPPORTED < ROWID_VALID_OTHER < ROWID_VALID_TRANSACTION
< ROWID_VALID_SESSION < ROWID_VALID_FOREVER
so conditional logic such as
if (metadata.getRowIdLifetime() > DatabaseMetaData.ROWID_VALID_TRANSACTION)
can be used. Valid Forever means valid across all Sessions, and valid for
a Session means valid across all its contained Transactions.getRowIdLifetime in interface DatabaseMetaDataRowIdSQLException - if a database access error occurspublic boolean supportsStoredFunctionsUsingCallSyntax()
throws SQLException
java.sql.DatabaseMetaDatasupportsStoredFunctionsUsingCallSyntax in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean autoCommitFailureClosesAllResultSets()
throws SQLException
java.sql.DatabaseMetaDataSQLException while autoCommit is true inidcates
that all open ResultSets are closed, even ones that are holdable. When a SQLException occurs while
autocommit is true, it is vendor specific whether the JDBC driver responds with a commit operation, a
rollback operation, or by doing neither a commit nor a rollback. A potential result of this difference
is in whether or not holdable ResultSets are closed.autoCommitFailureClosesAllResultSets in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic ResultSet getClientInfoProperties() throws SQLException
java.sql.DatabaseMetaData
The ResultSet is sorted by the NAME column
getClientInfoProperties in interface DatabaseMetaDataResultSet object; each row is a supported client info
property
SQLException - if a database access error occurs
public boolean isWrapperFor(Class<?> iface) throws SQLException
java.sql.WrapperisWrapperFor on the wrapped
object. If this does not implement the interface and is not a wrapper, return false.
This method should be implemented as a low-cost operation compared to unwrap so that
callers can use this method to avoid expensive unwrap calls that may fail. If this method
returns true then calling unwrap with the same argument should succeed.isWrapperFor in interface Wrapperiface - a Class defining an interface.SQLException - if an error occurs while determining whether this is a wrapper
for an object with the given interface.public <T> T unwrap(Class<T> iface) throws SQLException
java.sql.Wrapperunwrap recursively on the wrapped object
or a proxy for that result. If the receiver is not a
wrapper and does not implement the interface, then an SQLException is thrown.unwrap in interface Wrapperiface - A Class defining an interface that the result must implement.SQLException - If no object found that implements the interfacepublic ResultSet getFunctions(String catalog, String schemaPattern, String functionNamePattern) throws SQLException
java.sql.DatabaseMetaData
Only system and user function descriptions matching the schema and
function name criteria are returned. They are ordered by
FUNCTION_CAT, FUNCTION_SCHEM,
FUNCTION_NAME and
SPECIFIC_ NAME.
Each function description has the the following columns:
null)
null)
FUNCTION_NAME
for example with overload functions
A user may not have permission to execute any of the functions that are
returned by getFunctions
getFunctions in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchfunctionNamePattern - a function name pattern; must match the
function name as it is stored in the databaseResultSet - each row is a function descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getFunctionColumns(String catalog, String schemaPattern, String functionNamePattern, String columnNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly descriptions matching the schema, function and
parameter name criteria are returned. They are ordered by
FUNCTION_CAT, FUNCTION_SCHEM,
FUNCTION_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 ResultSet
is a parameter description, column description or
return type description with the following fields:
null)
null)
ResultSet
FUNCTION_NAME
for example with overload functions
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.
getFunctionColumns in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchfunctionNamePattern - a procedure name pattern; must match the
function name as it is stored in the databasecolumnNamePattern - a parameter name pattern; must match the
parameter or column name as it is stored in the databaseResultSet - each row describes a
user function parameter, column or return typeSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getPseudoColumns(String catalog, String schemaPattern, String tableNamePattern, String columnNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly column descriptions matching the catalog, schema, table
and column name criteria are returned. They are ordered by
TABLE_CAT,TABLE_SCHEM, TABLE_NAME
and COLUMN_NAME.
Each column description has the following columns:
null)
null)
PseudoColumnUsage.name()
null)
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.
getPseudoColumns in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtableNamePattern - a table name pattern; must match the
table name as it is stored in the databasecolumnNamePattern - a column name pattern; must match the column
name as it is stored in the databaseResultSet - each row is a column descriptionSQLException - if a database access error occursPseudoColumnUsagepublic boolean generatedKeyAlwaysReturned()
throws SQLException
java.sql.DatabaseMetaDatageneratedKeyAlwaysReturned in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occurspublic boolean supportsSavepoints()
throws SQLException
java.sql.DatabaseMetaDatasupportsSavepoints in interface DatabaseMetaDatatrue if savepoints are supported;
false otherwiseSQLException - if a database access error occurspublic boolean supportsNamedParameters()
throws SQLException
java.sql.DatabaseMetaDatasupportsNamedParameters in interface DatabaseMetaDatatrue if named parameters are supported;
false otherwiseSQLException - if a database access error occurspublic boolean supportsMultipleOpenResults()
throws SQLException
java.sql.DatabaseMetaDataResultSet objects
returned from a CallableStatement object
simultaneously.supportsMultipleOpenResults in interface DatabaseMetaDatatrue if a CallableStatement object
can return multiple ResultSet objects
simultaneously; false otherwiseSQLException - if a datanase access error occurspublic boolean supportsGetGeneratedKeys()
throws SQLException
java.sql.DatabaseMetaDatasupportsGetGeneratedKeys in interface DatabaseMetaDatatrue if auto-generated keys can be retrieved
after a statement has executed; false otherwise
If true is returned, the JDBC driver must support the
returning of auto-generated keys for at least SQL INSERT statements
SQLException - if a database access error occurspublic ResultSet getSuperTypes(String catalog, String schemaPattern, String typeNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly 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 ResultSet object returned by this method
describes the designated UDT and a direct supertype. A row has the following
columns:
null)
null)
null)
null)
Note: If the driver does not support type hierarchies, an empty result set is returned.
getSuperTypes in interface DatabaseMetaDatacatalog - a catalog name; "" retrieves those without a catalog;
null means drop catalog name from the selection criteriaschemaPattern - a schema name pattern; "" retrieves those
without a schematypeNamePattern - a UDT name pattern; may be a fully-qualified
nameResultSet object in which a row gives information
about the designated UDTSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getSuperTables(String catalog, String schemaPattern, String tableNamePattern) throws SQLException
java.sql.DatabaseMetaDataOnly 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:
null)
null)
Note: If the driver does not support type hierarchies, an empty result set is returned.
getSuperTables in interface DatabaseMetaDatacatalog - a catalog name; "" retrieves those without a catalog;
null means drop catalog name from the selection criteriaschemaPattern - a schema name pattern; "" retrieves those
without a schematableNamePattern - a table name pattern; may be a fully-qualified
nameResultSet object in which each row is a type descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public ResultSet getAttributes(String catalog, String schemaPattern, String typeNamePattern, String attributeNamePattern) throws SQLException
java.sql.DatabaseMetaData
Descriptions are returned only for attributes of UDTs matching the
catalog, schema, type, and attribute name criteria. They are ordered by
TYPE_CAT, TYPE_SCHEM,
TYPE_NAME and ORDINAL_POSITION. This description
does not contain inherited attributes.
The ResultSet object that is returned has the following
columns:
null)
null)
null)
null)
null if DATA_TYPE isn't REF)
null if DATA_TYPE isn't REF)
null if the DATA_TYPE isn't REF)
null if DATA_TYPE
isn't DISTINCT or user-generated REF)
getAttributes in interface DatabaseMetaDatacatalog - a catalog name; must match the catalog name as it
is stored in the database; "" retrieves those without a catalog;
null means that the catalog name should not be used to narrow
the searchschemaPattern - a schema name pattern; must match the schema name
as it is stored in the database; "" retrieves those without a schema;
null means that the schema name should not be used to narrow
the searchtypeNamePattern - a type name pattern; must match the
type name as it is stored in the databaseattributeNamePattern - an attribute name pattern; must match the attribute
name as it is declared in the databaseResultSet object in which each row is an
attribute descriptionSQLException - if a database access error occursDatabaseMetaData.getSearchStringEscape()public boolean supportsResultSetHoldability(int holdability)
throws SQLException
java.sql.DatabaseMetaDatasupportsResultSetHoldability in interface DatabaseMetaDataholdability - one of the following constants:
ResultSet.HOLD_CURSORS_OVER_COMMIT or
ResultSet.CLOSE_CURSORS_AT_COMMITtrue if so; false otherwiseSQLException - if a database access error occursConnectionpublic int getResultSetHoldability()
throws SQLException
java.sql.DatabaseMetaDataResultSet
objects.getResultSetHoldability in interface DatabaseMetaDataResultSet.HOLD_CURSORS_OVER_COMMIT or
ResultSet.CLOSE_CURSORS_AT_COMMITSQLException - if a database access error occurspublic int getDatabaseMajorVersion()
throws SQLException
java.sql.DatabaseMetaDatagetDatabaseMajorVersion in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getDatabaseMinorVersion()
throws SQLException
java.sql.DatabaseMetaDatagetDatabaseMinorVersion in interface DatabaseMetaDataSQLException - if a database access error occurspublic int getJDBCMajorVersion()
java.sql.DatabaseMetaDatagetJDBCMajorVersion in interface DatabaseMetaDatapublic int getJDBCMinorVersion()
java.sql.DatabaseMetaDatagetJDBCMinorVersion in interface DatabaseMetaDatapublic int getSQLStateType()
throws SQLException
java.sql.DatabaseMetaDataSQLException.getSQLState
is X/Open (now known as Open Group) SQL CLI or SQL:2003.getSQLStateType in interface DatabaseMetaDataSQLException - if a database access error occurspublic boolean locatorsUpdateCopy()
throws SQLException
java.sql.DatabaseMetaDatalocatorsUpdateCopy in interface DatabaseMetaDatatrue if updates are made to a copy of the LOB;
false if updates are made directly to the LOBSQLException - if a database access error occurspublic boolean supportsStatementPooling()
throws SQLException
java.sql.DatabaseMetaDatasupportsStatementPooling in interface DatabaseMetaDatatrue if so; false otherwiseSQLException - if a database access error occursCopyright © 2017 PostgreSQL Global Development Group. All rights reserved.