|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object net.sourceforge.jtds.jdbc.JtdsDatabaseMetaData
jTDS implementation of the java.sql.DatabaseMetaData interface.
Implementation note:
This is basically the code from the original jTDS driver. Main changes relate to the need to support the new ResultSet implementation.
TODO: Many of the system limits need to be revised to more accurately reflect the target database constraints. In many cases limits are soft and determined by bytes per column for example. Probably more of these functions should be altered to return 0 but for now the original jTDS values are returned.
Field Summary | |
(package private) java.lang.Boolean |
caseSensitive
Boolean.TRUE if identifiers are case sensitive (the server
was installed that way). |
private ConnectionJDBC2 |
connection
|
private int |
serverType
|
(package private) static int |
sqlStateXOpen
|
(package private) int |
sysnameLength
Length of a sysname object (table name, catalog name etc.) -- 128 for TDS 7.0, 30 for earlier versions. |
private int |
tdsVersion
|
Fields inherited from interface java.sql.DatabaseMetaData |
attributeNoNulls, attributeNullable, attributeNullableUnknown, bestRowNotPseudo, bestRowPseudo, bestRowSession, bestRowTemporary, bestRowTransaction, bestRowUnknown, columnNoNulls, columnNullable, columnNullableUnknown, importedKeyCascade, importedKeyInitiallyDeferred, importedKeyInitiallyImmediate, importedKeyNoAction, importedKeyNotDeferrable, importedKeyRestrict, importedKeySetDefault, importedKeySetNull, procedureColumnIn, procedureColumnInOut, procedureColumnOut, procedureColumnResult, procedureColumnReturn, procedureColumnUnknown, procedureNoNulls, procedureNoResult, procedureNullable, procedureNullableUnknown, procedureResultUnknown, procedureReturnsResult, sqlStateSQL99, tableIndexClustered, tableIndexHashed, tableIndexOther, tableIndexStatistic, typeNoNulls, typeNullable, typeNullableUnknown, typePredBasic, typePredChar, typePredNone, typeSearchable, versionColumnNotPseudo, versionColumnPseudo, versionColumnUnknown |
Constructor Summary | |
JtdsDatabaseMetaData(ConnectionJDBC2 connection)
|
Method Summary | |
boolean |
allProceduresAreCallable()
Can all the procedures returned by getProcedures be called by the current user? |
boolean |
allTablesAreSelectable()
Can all the tables returned by getTable be SELECTed by the current user? |
private static CachedResultSet |
createTypeInfoResultSet(JtdsResultSet rs,
boolean useLOBs)
|
boolean |
dataDefinitionCausesTransactionCommit()
Does a data definition statement within a transaction force the transaction to commit? |
boolean |
dataDefinitionIgnoredInTransactions()
Is a data definition statement within a transaction ignored? |
boolean |
deletesAreDetected(int type)
JDBC 2.0 Indicates whether or not a visible row delete can be detected by calling ResultSet.rowDeleted(). |
boolean |
doesMaxRowSizeIncludeBlobs()
Did getMaxRowSize() include LONGVARCHAR and LONGVARBINARY blobs? |
java.sql.ResultSet |
getAttributes(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String typeNamePattern,
java.lang.String attributeNamePattern)
|
java.sql.ResultSet |
getBestRowIdentifier(java.lang.String catalog,
java.lang.String schema,
java.lang.String table,
int scope,
boolean nullable)
Get a description of a table's optimal set of columns that uniquely identifies a row. |
java.sql.ResultSet |
getCatalogs()
Get the catalog names available in this database. |
java.lang.String |
getCatalogSeparator()
What's the separator between catalog and table name? |
java.lang.String |
getCatalogTerm()
What's the database vendor's preferred term for "catalog"? |
java.sql.ResultSet |
getColumnPrivileges(java.lang.String catalog,
java.lang.String schema,
java.lang.String table,
java.lang.String columnNamePattern)
Get a description of the access rights for a table's columns. |
java.sql.ResultSet |
getColumns(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String tableNamePattern,
java.lang.String columnNamePattern)
Get a description of table columns available in a catalog. |
java.sql.Connection |
getConnection()
JDBC 2.0 Retrieves the connection that produced this metadata object. |
java.sql.ResultSet |
getCrossReference(java.lang.String primaryCatalog,
java.lang.String primarySchema,
java.lang.String primaryTable,
java.lang.String foreignCatalog,
java.lang.String foreignSchema,
java.lang.String foreignTable)
Get a description of the foreign key columns in the foreign key table that reference the primary key columns of the primary key table (describe how one table imports another's key). |
int |
getDatabaseMajorVersion()
Returns the database major version. |
int |
getDatabaseMinorVersion()
Returns the database minor version. |
java.lang.String |
getDatabaseProductName()
Returns the name of this database product. |
java.lang.String |
getDatabaseProductVersion()
Returns the version of this database product. |
int |
getDefaultTransactionIsolation()
Returns the database's default transaction isolation level. |
int |
getDriverMajorVersion()
Returns this JDBC driver's major version number. |
int |
getDriverMinorVersion()
Returns this JDBC driver's minor version number. |
java.lang.String |
getDriverName()
Returns the name of this JDBC driver. |
java.lang.String |
getDriverVersion()
Returns the version of this JDBC driver. |
java.sql.ResultSet |
getExportedKeys(java.lang.String catalog,
java.lang.String schema,
java.lang.String table)
Get a description of the foreign key columns that reference a table's primary key columns (the foreign keys exported by a table). |
java.lang.String |
getExtraNameCharacters()
Get all the "extra" characters that can be used in unquoted identifier names (those beyond a-z, A-Z, 0-9 and _). |
java.lang.String |
getIdentifierQuoteString()
Returns the string used to quote SQL identifiers. |
java.sql.ResultSet |
getImportedKeys(java.lang.String catalog,
java.lang.String schema,
java.lang.String table)
Get a description of the primary key columns that are referenced by a table's foreign key columns (the primary keys imported by a table). |
java.sql.ResultSet |
getIndexInfo(java.lang.String catalog,
java.lang.String schema,
java.lang.String table,
boolean unique,
boolean approximate)
Get a description of a table's indices and statistics. |
int |
getJDBCMajorVersion()
Returns the JDBC major version. |
int |
getJDBCMinorVersion()
Returns the JDBC minor version. |
int |
getMaxBinaryLiteralLength()
How many hex characters can you have in an inline binary literal? |
int |
getMaxCatalogNameLength()
What's the maximum length of a catalog name? |
int |
getMaxCharLiteralLength()
What's the max length for a character literal? |
int |
getMaxColumnNameLength()
What's the limit on column name length? |
int |
getMaxColumnsInGroupBy()
What's the maximum number of columns in a "GROUP BY" clause? |
int |
getMaxColumnsInIndex()
What's the maximum number of columns allowed in an index? |
int |
getMaxColumnsInOrderBy()
What's the maximum number of columns in an "ORDER BY" clause? |
int |
getMaxColumnsInSelect()
What's the maximum number of columns in a "SELECT" list? |
int |
getMaxColumnsInTable()
What's the maximum number of columns in a table? |
int |
getMaxConnections()
How many active connections can we have at a time to this database? |
int |
getMaxCursorNameLength()
What's the maximum cursor name length? |
int |
getMaxIndexLength()
What's the maximum length of an index (in bytes)? |
int |
getMaxProcedureNameLength()
What's the maximum length of a procedure name? |
int |
getMaxRowSize()
What's the maximum length of a single row? |
int |
getMaxSchemaNameLength()
What's the maximum length allowed for a schema name? |
int |
getMaxStatementLength()
What's the maximum length of a SQL statement? |
int |
getMaxStatements()
How many active statements can we have open at one time to this database? |
int |
getMaxTableNameLength()
What's the maximum length of a table name? |
int |
getMaxTablesInSelect()
What's the maximum number of tables in a SELECT? |
int |
getMaxUserNameLength()
What's the maximum length of a user name? |
java.lang.String |
getNumericFunctions()
Get a comma separated list of math functions. |
java.sql.ResultSet |
getPrimaryKeys(java.lang.String catalog,
java.lang.String schema,
java.lang.String table)
Get a description of a table's primary key columns. |
java.sql.ResultSet |
getProcedureColumns(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String procedureNamePattern,
java.lang.String columnNamePattern)
Get a description of a catalog's stored procedure parameters and result columns. |
java.sql.ResultSet |
getProcedures(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String procedureNamePattern)
Get a description of stored procedures available in a catalog. |
java.lang.String |
getProcedureTerm()
What's the database vendor's preferred term for "procedure"? |
int |
getResultSetHoldability()
|
java.sql.ResultSet |
getSchemas()
Get the schema names available in this database. |
java.lang.String |
getSchemaTerm()
What's the database vendor's preferred term for "schema"? |
java.lang.String |
getSearchStringEscape()
This is the string that can be used to escape '_' or '%' in the string pattern style catalog search parameters. |
private static java.util.Collection |
getSortedTypes(java.sql.ResultSet rs,
boolean useLOBs)
|
java.lang.String |
getSQLKeywords()
Get a comma separated list of all a database's SQL keywords that are NOT also SQL92 keywords. |
int |
getSQLStateType()
|
java.lang.String |
getStringFunctions()
Get a comma separated list of string functions. |
java.sql.ResultSet |
getSuperTables(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String tableNamePattern)
|
java.sql.ResultSet |
getSuperTypes(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String typeNamePattern)
|
java.lang.String |
getSystemFunctions()
Get a comma separated list of system functions. |
java.sql.ResultSet |
getTablePrivileges(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String tableNamePattern)
Get a description of the access rights for each table available in a catalog. |
java.sql.ResultSet |
getTables(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String tableNamePattern,
java.lang.String[] types)
Get a description of tables available in a catalog. |
java.sql.ResultSet |
getTableTypes()
Get the table types available in this database. |
java.lang.String |
getTimeDateFunctions()
Get a comma separated list of time and date functions. |
java.sql.ResultSet |
getTypeInfo()
Get a description of all the standard SQL types supported by this database. |
java.sql.ResultSet |
getUDTs(java.lang.String catalog,
java.lang.String schemaPattern,
java.lang.String typeNamePattern,
int[] types)
JDBC 2.0 Gets a description of the user-defined types defined in a particular schema. |
java.lang.String |
getURL()
What's the URL for this database? |
java.lang.String |
getUserName()
What's our user name as known to the database? |
java.sql.ResultSet |
getVersionColumns(java.lang.String catalog,
java.lang.String schema,
java.lang.String table)
Get a description of a table's columns that are automatically updated when any value in a row is updated. |
boolean |
insertsAreDetected(int type)
JDBC 2.0 Indicates whether or not a visible row insert can be detected by calling ResultSet.rowInserted(). |
boolean |
isCatalogAtStart()
Retrieves whether a catalog appears at the start of a fully qualified table name. |
boolean |
isReadOnly()
Is the database in read-only mode? |
boolean |
locatorsUpdateCopy()
Returns true if updates are made to a copy of the LOB; returns
false if LOB updates are made directly to the database.
|
boolean |
nullPlusNonNullIsNull()
Retrieves whether this database supports concatenations between NULL and non-NULL values being
NULL . |
boolean |
nullsAreSortedAtEnd()
Are NULL values sorted at the end regardless of sort order? |
boolean |
nullsAreSortedAtStart()
Are NULL values sorted at the start regardless of sort order? |
boolean |
nullsAreSortedHigh()
Are NULL values sorted high? |
boolean |
nullsAreSortedLow()
Are NULL values sorted low? |
boolean |
othersDeletesAreVisible(int type)
JDBC 2.0 Indicates whether deletes made by others are visible. |
boolean |
othersInsertsAreVisible(int type)
JDBC 2.0 Indicates whether inserts made by others are visible. |
boolean |
othersUpdatesAreVisible(int type)
JDBC 2.0 Indicates whether updates made by others are visible. |
boolean |
ownDeletesAreVisible(int type)
JDBC 2.0 Indicates whether a result set's own deletes are visible. |
boolean |
ownInsertsAreVisible(int type)
JDBC 2.0 Indicates whether a result set's own inserts are visible. |
boolean |
ownUpdatesAreVisible(int type)
JDBC 2.0 Indicates whether a result set's own updates are visible. |
private static java.lang.String |
processEscapes(java.lang.String pattern)
Format the supplied search pattern to transform the escape \x into [x]. |
private void |
setCaseSensitiveFlag()
|
boolean |
storesLowerCaseIdentifiers()
Does the database treat mixed case unquoted SQL identifiers as case insensitive and store them in lower case? |
boolean |
storesLowerCaseQuotedIdentifiers()
Does the database treat mixed case quoted SQL identifiers as case insensitive and store them in lower case? |
boolean |
storesMixedCaseIdentifiers()
Does the database treat mixed case unquoted SQL identifiers as case insensitive and store them in mixed case? |
boolean |
storesMixedCaseQuotedIdentifiers()
Does the database treat mixed case quoted SQL identifiers as case insensitive and store them in mixed case? |
boolean |
storesUpperCaseIdentifiers()
Does the database treat mixed case unquoted SQL identifiers as case insensitive and store them in upper case? |
boolean |
storesUpperCaseQuotedIdentifiers()
Does the database treat mixed case quoted SQL identifiers as case insensitive and store them in upper case? |
boolean |
supportsAlterTableWithAddColumn()
Is "ALTER TABLE" with add column supported? |
boolean |
supportsAlterTableWithDropColumn()
Is "ALTER TABLE" with drop column supported? |
boolean |
supportsANSI92EntryLevelSQL()
Retrieves whether this database supports the ANSI92 entry level SQL grammar. |
boolean |
supportsANSI92FullSQL()
Is the ANSI92 full SQL grammar supported? |
boolean |
supportsANSI92IntermediateSQL()
Is the ANSI92 intermediate SQL grammar supported? |
boolean |
supportsBatchUpdates()
JDBC 2.0 Indicates whether the driver supports batch updates. |
boolean |
supportsCatalogsInDataManipulation()
Can a catalog name be used in a data manipulation statement? |
boolean |
supportsCatalogsInIndexDefinitions()
Can a catalog name be used in an index definition statement? |
boolean |
supportsCatalogsInPrivilegeDefinitions()
Can a catalog name be used in a privilege definition statement? |
boolean |
supportsCatalogsInProcedureCalls()
Can a catalog name be used in a procedure call statement? |
boolean |
supportsCatalogsInTableDefinitions()
Can a catalog name be used in a table definition statement? |
boolean |
supportsColumnAliasing()
Retrieves whether this database supports column aliasing. |
boolean |
supportsConvert()
Is the CONVERT function between SQL types supported? |
boolean |
supportsConvert(int fromType,
int toType)
Is CONVERT between the given SQL types supported? |
boolean |
supportsCoreSQLGrammar()
Is the ODBC Core SQL grammar supported? |
boolean |
supportsCorrelatedSubqueries()
Retrieves whether this database supports correlated subqueries. |
boolean |
supportsDataDefinitionAndDataManipulationTransactions()
Are both data definition and data manipulation statements within a transaction supported? |
boolean |
supportsDataManipulationTransactionsOnly()
Are only data manipulation statements within a transaction supported? |
boolean |
supportsDifferentTableCorrelationNames()
If table correlation names are supported, are they restricted to be different from the names of the tables? |
boolean |
supportsExpressionsInOrderBy()
Are expressions in "ORDER BY" lists supported? |
boolean |
supportsExtendedSQLGrammar()
Is the ODBC Extended SQL grammar supported? |
boolean |
supportsFullOuterJoins()
Are full nested outer joins supported? |
boolean |
supportsGetGeneratedKeys()
Returns true if getting auto-generated keys is supported after a
statment is executed; returns false otherwise |
boolean |
supportsGroupBy()
Is some form of "GROUP BY" clause supported? |
boolean |
supportsGroupByBeyondSelect()
Can a "GROUP BY" clause add columns not in the SELECT provided it specifies all the columns in the SELECT? |
boolean |
supportsGroupByUnrelated()
Can a "GROUP BY" clause use columns not in the SELECT? |
boolean |
supportsIntegrityEnhancementFacility()
Is the SQL Integrity Enhancement Facility supported? |
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()
Retrieves whether this database treats mixed case unquoted SQL identifiers as case sensitive and as a result stores them in mixed case. |
boolean |
supportsMixedCaseQuotedIdentifiers()
Retrieves whether this database treats mixed case quoted SQL identifiers as case sensitive and as a result stores them in mixed case. |
boolean |
supportsMultipleOpenResults()
Returns true if Callable statements can return multiple result sets;
returns false if they can only return one result set. |
boolean |
supportsMultipleResultSets()
Are multiple ResultSets from a single execute supported? |
boolean |
supportsMultipleTransactions()
Can we have multiple transactions open at once (on different connections)? |
boolean |
supportsNamedParameters()
Returns true if the database supports named parameters;
returns false if the database does not support named parameters. |
boolean |
supportsNonNullableColumns()
Retrieves whether columns in this database may be defined as non-nullable. |
boolean |
supportsOpenCursorsAcrossCommit()
Can cursors remain open across commits? |
boolean |
supportsOpenCursorsAcrossRollback()
Can cursors remain open across rollbacks? |
boolean |
supportsOpenStatementsAcrossCommit()
Can statements remain open across commits? |
boolean |
supportsOpenStatementsAcrossRollback()
Can statements remain open across rollbacks? |
boolean |
supportsOrderByUnrelated()
Can an "ORDER BY" clause use columns not in the SELECT? |
boolean |
supportsOuterJoins()
Is some form of outer join supported? |
boolean |
supportsPositionedDelete()
Is positioned DELETE supported? |
boolean |
supportsPositionedUpdate()
Is positioned UPDATE supported? |
boolean |
supportsResultSetConcurrency(int type,
int concurrency)
Does the database support the concurrency type in combination with the given result set type? |
boolean |
supportsResultSetHoldability(int param)
|
boolean |
supportsResultSetType(int type)
Does the database support the given result set type? |
boolean |
supportsSavepoints()
Returns true if savepoints are supported; returns
false otherwise |
boolean |
supportsSchemasInDataManipulation()
Can a schema name be used in a data manipulation statement? |
boolean |
supportsSchemasInIndexDefinitions()
Can a schema name be used in an index definition statement? |
boolean |
supportsSchemasInPrivilegeDefinitions()
Can a schema name be used in a privilege definition statement? |
boolean |
supportsSchemasInProcedureCalls()
Can a schema name be used in a procedure call statement? |
boolean |
supportsSchemasInTableDefinitions()
Can a schema name be used in a table definition statement? |
boolean |
supportsSelectForUpdate()
Is SELECT for UPDATE supported? |
boolean |
supportsStatementPooling()
Returns true if the database supports statement pooling;
returns false otherwise. |
boolean |
supportsStoredProcedures()
Are stored procedure calls using the stored procedure escape syntax supported? |
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 statements. |
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)
Does the database support the given transaction isolation level? |
boolean |
supportsTransactions()
Retrieves whether this database supports transactions. |
boolean |
supportsUnion()
Is SQL UNION supported? |
boolean |
supportsUnionAll()
Is SQL UNION ALL supported? |
private java.lang.String |
syscall(java.lang.String catalog,
java.lang.String call)
Format the supplied procedure call as a valid JDBC call escape. |
boolean |
updatesAreDetected(int type)
JDBC 2.0 Indicates whether or not a visible row update can be detected by calling the method ResultSet.rowUpdated . |
private static void |
upperCaseColumnNames(JtdsResultSet results)
Uppercase all column names. |
boolean |
usesLocalFilePerTable()
Does the database use a file for each table? |
boolean |
usesLocalFiles()
Does the database store tables in a local file? |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
static final int sqlStateXOpen
private final int tdsVersion
private final int serverType
private final ConnectionJDBC2 connection
int sysnameLength
java.lang.Boolean caseSensitive
Boolean.TRUE
if identifiers are case sensitive (the server
was installed that way). Initially null
, set the first time
any of the methods that check this are called.
Constructor Detail |
public JtdsDatabaseMetaData(ConnectionJDBC2 connection)
Method Detail |
public boolean allProceduresAreCallable() throws java.sql.SQLException
allProceduresAreCallable
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean allTablesAreSelectable() throws java.sql.SQLException
allTablesAreSelectable
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean dataDefinitionCausesTransactionCommit() throws java.sql.SQLException
dataDefinitionCausesTransactionCommit
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean dataDefinitionIgnoredInTransactions() throws java.sql.SQLException
dataDefinitionIgnoredInTransactions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean doesMaxRowSizeIncludeBlobs() throws java.sql.SQLException
doesMaxRowSizeIncludeBlobs
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getBestRowIdentifier(java.lang.String catalog, java.lang.String schema, java.lang.String table, int scope, boolean nullable) throws java.sql.SQLException
Each column description has the following columns:
getBestRowIdentifier
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a catalog;
null
means drop catalog name from the selection criteriaschema
- a schema name; "" retrieves those without a schematable
- a table namescope
- the scope of interest; use same values as SCOPEnullable
- include columns that are nullable?
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getCatalogs() throws java.sql.SQLException
The catalog column is:
getCatalogs
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getCatalogSeparator() throws java.sql.SQLException
getCatalogSeparator
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getCatalogTerm() throws java.sql.SQLException
getCatalogTerm
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getColumnPrivileges(java.lang.String catalog, java.lang.String schema, java.lang.String table, java.lang.String columnNamePattern) throws java.sql.SQLException
Only privileges matching the column name criteria are returned. They are ordered by COLUMN_NAME and PRIVILEGE.
Each privilige description has the following columns:
getColumnPrivileges
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a catalog;
null
means drop catalog name from the selection criteriaschema
- a schema name; "" retrieves those without a schema
schematable
- a table namecolumnNamePattern
- a column name pattern
java.sql.SQLException
- if a database-access error occurs.getSearchStringEscape()
public java.sql.ResultSet getColumns(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String tableNamePattern, java.lang.String columnNamePattern) throws java.sql.SQLException
Only column descriptions matching the catalog, schema, table and column name criteria are returned. They are ordered by TABLE_SCHEM, TABLE_NAME and ORDINAL_POSITION.
Each column description has the following columns:
getColumns
in interface java.sql.DatabaseMetaData
catalog
- 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 patterncolumnNamePattern
- a column name pattern
java.sql.SQLException
- if a database-access error occurs.getSearchStringEscape()
public java.sql.ResultSet getCrossReference(java.lang.String primaryCatalog, java.lang.String primarySchema, java.lang.String primaryTable, java.lang.String foreignCatalog, java.lang.String foreignSchema, java.lang.String foreignTable) throws java.sql.SQLException
Each foreign key column description has the following columns:
getCrossReference
in interface java.sql.DatabaseMetaData
primaryCatalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaprimarySchema
- a schema name pattern; "" retrieves those without a schemaprimaryTable
- the table name that exports the keyforeignCatalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaforeignSchema
- a schema name pattern; "" retrieves those without a schemaforeignTable
- the table name that imports the key
java.sql.SQLException
- if a database-access error occurs.getImportedKeys(java.lang.String, java.lang.String, java.lang.String)
public java.lang.String getDatabaseProductName() throws java.sql.SQLException
getDatabaseProductName
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getDatabaseProductVersion() throws java.sql.SQLException
getDatabaseProductVersion
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getDefaultTransactionIsolation() throws java.sql.SQLException
getDefaultTransactionIsolation
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.Connection
public int getDriverMajorVersion()
getDriverMajorVersion
in interface java.sql.DatabaseMetaData
public int getDriverMinorVersion()
getDriverMinorVersion
in interface java.sql.DatabaseMetaData
public java.lang.String getDriverName() throws java.sql.SQLException
getDriverName
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getDriverVersion() throws java.sql.SQLException
getDriverVersion
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getExportedKeys(java.lang.String catalog, java.lang.String schema, java.lang.String table) throws java.sql.SQLException
Each foreign key column description has the following columns:
getExportedKeys
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschema
- a schema name; "" retrieves those without a schematable
- a table name
java.sql.SQLException
- if a database-access error occurs.getImportedKeys(java.lang.String, java.lang.String, java.lang.String)
public java.lang.String getExtraNameCharacters() throws java.sql.SQLException
getExtraNameCharacters
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getIdentifierQuoteString() throws java.sql.SQLException
getIdentifierQuoteString
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getImportedKeys(java.lang.String catalog, java.lang.String schema, java.lang.String table) throws java.sql.SQLException
Each primary key column description has the following columns:
getImportedKeys
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschema
- a schema name; "" retrieves those without a schematable
- a table name
java.sql.SQLException
- if a database-access error occurs.getExportedKeys(java.lang.String, java.lang.String, java.lang.String)
public java.sql.ResultSet getIndexInfo(java.lang.String catalog, java.lang.String schema, java.lang.String table, boolean unique, boolean approximate) throws java.sql.SQLException
Each index column description has the following columns:
getIndexInfo
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschema
- a schema name; "" retrieves those without a schematable
- a table nameunique
- 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 accurate
java.sql.SQLException
- if a database-access error occurs.public int getMaxBinaryLiteralLength() throws java.sql.SQLException
getMaxBinaryLiteralLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxCatalogNameLength() throws java.sql.SQLException
getMaxCatalogNameLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxCharLiteralLength() throws java.sql.SQLException
getMaxCharLiteralLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxColumnNameLength() throws java.sql.SQLException
getMaxColumnNameLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxColumnsInGroupBy() throws java.sql.SQLException
getMaxColumnsInGroupBy
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxColumnsInIndex() throws java.sql.SQLException
getMaxColumnsInIndex
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxColumnsInOrderBy() throws java.sql.SQLException
getMaxColumnsInOrderBy
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxColumnsInSelect() throws java.sql.SQLException
getMaxColumnsInSelect
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxColumnsInTable() throws java.sql.SQLException
getMaxColumnsInTable
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxConnections() throws java.sql.SQLException
getMaxConnections
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxCursorNameLength() throws java.sql.SQLException
getMaxCursorNameLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxIndexLength() throws java.sql.SQLException
getMaxIndexLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxProcedureNameLength() throws java.sql.SQLException
getMaxProcedureNameLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxRowSize() throws java.sql.SQLException
getMaxRowSize
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxSchemaNameLength() throws java.sql.SQLException
getMaxSchemaNameLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxStatementLength() throws java.sql.SQLException
getMaxStatementLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxStatements() throws java.sql.SQLException
getMaxStatements
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxTableNameLength() throws java.sql.SQLException
getMaxTableNameLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxTablesInSelect() throws java.sql.SQLException
getMaxTablesInSelect
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public int getMaxUserNameLength() throws java.sql.SQLException
getMaxUserNameLength
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getNumericFunctions() throws java.sql.SQLException
getNumericFunctions
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getPrimaryKeys(java.lang.String catalog, java.lang.String schema, java.lang.String table) throws java.sql.SQLException
Each primary key column description has the following columns:
getPrimaryKeys
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschema
- a schema name; "" retrieves those without a schematable
- a table name
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getProcedureColumns(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String procedureNamePattern, java.lang.String columnNamePattern) throws java.sql.SQLException
Only descriptions matching the schema, procedure and parameter name criteria are returned. They are ordered by PROCEDURE_SCHEM and PROCEDURE_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:
Note: Some databases may not return the column descriptions for a procedure. Additional columns beyond REMARKS can be defined by the database.
getProcedureColumns
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschemaPattern
- a schema name pattern; "" retrieves those
without a schemaprocedureNamePattern
- a procedure name patterncolumnNamePattern
- a column name pattern
java.sql.SQLException
- if a database-access error occurs.getSearchStringEscape()
public java.sql.ResultSet getProcedures(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String procedureNamePattern) throws java.sql.SQLException
Only procedure descriptions matching the schema and procedure name criteria are returned. They are ordered by PROCEDURE_SCHEM, and PROCEDURE_NAME.
Each procedure description has the the following columns:
getProcedures
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschemaPattern
- a schema name pattern; "" retrieves those
without a schemaprocedureNamePattern
- a procedure name pattern
java.sql.SQLException
- if a database-access error occurs.getSearchStringEscape()
public java.lang.String getProcedureTerm() throws java.sql.SQLException
getProcedureTerm
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getSchemas() throws java.sql.SQLException
The schema column is:
null
, JDBC 3.0)
getSchemas
in interface java.sql.DatabaseMetaData
ResultSet
object in which each row is a schema description
java.sql.SQLException
- if a database access error occurspublic java.lang.String getSchemaTerm() throws java.sql.SQLException
getSchemaTerm
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getSearchStringEscape() throws java.sql.SQLException
The '_' character represents any single character.
The '%' character represents any sequence of zero or more characters.
getSearchStringEscape
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getSQLKeywords() throws java.sql.SQLException
getSQLKeywords
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getStringFunctions() throws java.sql.SQLException
getStringFunctions
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getSystemFunctions() throws java.sql.SQLException
getSystemFunctions
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getTablePrivileges(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String tableNamePattern) throws java.sql.SQLException
Only privileges matching the schema and table name criteria are returned. They are ordered by TABLE_SCHEM, TABLE_NAME, and PRIVILEGE.
Each privilige description has the following columns:
getTablePrivileges
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschemaPattern
- a schema name pattern; "" retrieves those
without a schematableNamePattern
- a table name pattern
java.sql.SQLException
- if a database-access error occurs.getSearchStringEscape()
public java.sql.ResultSet getTables(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String tableNamePattern, java.lang.String[] types) throws java.sql.SQLException
Only table descriptions matching the catalog, schema, table name and type criteria are returned. They are ordered by TABLE_TYPE, TABLE_SCHEM and TABLE_NAME.
Each table description has the following columns:
null
)
null
)
null
)
null
)
null
)
Note: Some databases may not return information for all tables.
getTables
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschemaPattern
- a schema name pattern; "" retrieves those
without a schematableNamePattern
- a table name patterntypes
- a list of table types to include; null returns all types
java.sql.SQLException
- if a database-access error occurs.getSearchStringEscape()
public java.sql.ResultSet getTableTypes() throws java.sql.SQLException
The table type is:
getTableTypes
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.lang.String getTimeDateFunctions() throws java.sql.SQLException
getTimeDateFunctions
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getTypeInfo() throws java.sql.SQLException
Each type description has the following columns:
getTypeInfo
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getUDTs(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String typeNamePattern, int[] types) throws java.sql.SQLException
Only types matching the catalog, schema, type name and type criteria are returned. They are ordered by DATA_TYPE, 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:
Note: If the driver does not support UDTs, an empty result set is returned.
getUDTs
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschemaPattern
- a schema name pattern; "" retrieves those
without a schematypeNamePattern
- a type name pattern; may be a fully-qualified
nametypes
- a list of user-named types to include
(JAVA_OBJECT, STRUCT, or DISTINCT); null returns all types
java.sql.SQLException
- if a database access error occurspublic java.lang.String getURL() throws java.sql.SQLException
getURL
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurspublic java.lang.String getUserName() throws java.sql.SQLException
getUserName
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public java.sql.ResultSet getVersionColumns(java.lang.String catalog, java.lang.String schema, java.lang.String table) throws java.sql.SQLException
Each column description has the following columns:
getVersionColumns
in interface java.sql.DatabaseMetaData
catalog
- a catalog name; "" retrieves those without a
null
means drop catalog name from the selection criteriaschema
- a schema name; "" retrieves those without a schematable
- a table name
java.sql.SQLException
- if a database-access error occurs.public boolean isCatalogAtStart() throws java.sql.SQLException
isCatalogAtStart
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public boolean isReadOnly() throws java.sql.SQLException
isReadOnly
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public java.sql.Connection getConnection() throws java.sql.SQLException
getConnection
in interface java.sql.DatabaseMetaData
java.sql.SQLException
- if a database-access error occurs.public boolean nullPlusNonNullIsNull() throws java.sql.SQLException
NULL
and non-NULL
values being
NULL
.
nullPlusNonNullIsNull
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean nullsAreSortedAtEnd() throws java.sql.SQLException
nullsAreSortedAtEnd
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean nullsAreSortedAtStart() throws java.sql.SQLException
nullsAreSortedAtStart
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean nullsAreSortedHigh() throws java.sql.SQLException
nullsAreSortedHigh
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean nullsAreSortedLow() throws java.sql.SQLException
nullsAreSortedLow
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean storesLowerCaseIdentifiers() throws java.sql.SQLException
storesLowerCaseIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean storesLowerCaseQuotedIdentifiers() throws java.sql.SQLException
storesLowerCaseQuotedIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean storesMixedCaseIdentifiers() throws java.sql.SQLException
storesMixedCaseIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean storesMixedCaseQuotedIdentifiers() throws java.sql.SQLException
storesMixedCaseQuotedIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean storesUpperCaseIdentifiers() throws java.sql.SQLException
storesUpperCaseIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean storesUpperCaseQuotedIdentifiers() throws java.sql.SQLException
storesUpperCaseQuotedIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsAlterTableWithAddColumn() throws java.sql.SQLException
supportsAlterTableWithAddColumn
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsAlterTableWithDropColumn() throws java.sql.SQLException
supportsAlterTableWithDropColumn
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsANSI92EntryLevelSQL() throws java.sql.SQLException
supportsANSI92EntryLevelSQL
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsANSI92FullSQL() throws java.sql.SQLException
supportsANSI92FullSQL
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsANSI92IntermediateSQL() throws java.sql.SQLException
supportsANSI92IntermediateSQL
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsCatalogsInDataManipulation() throws java.sql.SQLException
supportsCatalogsInDataManipulation
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsCatalogsInIndexDefinitions() throws java.sql.SQLException
supportsCatalogsInIndexDefinitions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsCatalogsInPrivilegeDefinitions() throws java.sql.SQLException
supportsCatalogsInPrivilegeDefinitions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsCatalogsInProcedureCalls() throws java.sql.SQLException
supportsCatalogsInProcedureCalls
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsCatalogsInTableDefinitions() throws java.sql.SQLException
supportsCatalogsInTableDefinitions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsColumnAliasing() throws java.sql.SQLException
If so, the SQL AS clause can be used to provide names for computed columns or to provide alias names for columns as required. A JDBC-Compliant driver always returns true.
supportsColumnAliasing
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsConvert() throws java.sql.SQLException
supportsConvert
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsConvert(int fromType, int toType) throws java.sql.SQLException
supportsConvert
in interface java.sql.DatabaseMetaData
fromType
- the type to convert fromtoType
- the type to convert to
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsCoreSQLGrammar() throws java.sql.SQLException
supportsCoreSQLGrammar
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsCorrelatedSubqueries() throws java.sql.SQLException
supportsCorrelatedSubqueries
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsDataDefinitionAndDataManipulationTransactions() throws java.sql.SQLException
supportsDataDefinitionAndDataManipulationTransactions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsDataManipulationTransactionsOnly() throws java.sql.SQLException
supportsDataManipulationTransactionsOnly
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsDifferentTableCorrelationNames() throws java.sql.SQLException
supportsDifferentTableCorrelationNames
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsExpressionsInOrderBy() throws java.sql.SQLException
supportsExpressionsInOrderBy
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsExtendedSQLGrammar() throws java.sql.SQLException
supportsExtendedSQLGrammar
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsFullOuterJoins() throws java.sql.SQLException
supportsFullOuterJoins
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsGroupBy() throws java.sql.SQLException
supportsGroupBy
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsGroupByBeyondSelect() throws java.sql.SQLException
supportsGroupByBeyondSelect
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsGroupByUnrelated() throws java.sql.SQLException
supportsGroupByUnrelated
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsIntegrityEnhancementFacility() throws java.sql.SQLException
supportsIntegrityEnhancementFacility
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsLikeEscapeClause() throws java.sql.SQLException
LIKE
escape clause.
supportsLikeEscapeClause
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsLimitedOuterJoins() throws java.sql.SQLException
true
if the method
supportsFullOuterJoins
returns true
).
supportsLimitedOuterJoins
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsMinimumSQLGrammar() throws java.sql.SQLException
supportsMinimumSQLGrammar
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsMixedCaseIdentifiers() throws java.sql.SQLException
supportsMixedCaseIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsMixedCaseQuotedIdentifiers() throws java.sql.SQLException
supportsMixedCaseQuotedIdentifiers
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsMultipleResultSets() throws java.sql.SQLException
supportsMultipleResultSets
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsMultipleTransactions() throws java.sql.SQLException
supportsMultipleTransactions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsNonNullableColumns() throws java.sql.SQLException
supportsNonNullableColumns
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsOpenCursorsAcrossCommit() throws java.sql.SQLException
supportsOpenCursorsAcrossCommit
in interface java.sql.DatabaseMetaData
true
if cursors always remain open;
false
if they might not remain open
java.sql.SQLException
- if a database-access error occurs.public boolean supportsOpenCursorsAcrossRollback() throws java.sql.SQLException
supportsOpenCursorsAcrossRollback
in interface java.sql.DatabaseMetaData
true
if cursors always remain open;
false
if they might not remain open
java.sql.SQLException
- if a database-access error occurs.public boolean supportsOpenStatementsAcrossCommit() throws java.sql.SQLException
supportsOpenStatementsAcrossCommit
in interface java.sql.DatabaseMetaData
true
if statements always remain open;
false
if they might not remain open
java.sql.SQLException
- if a database-access error occurs.public boolean supportsOpenStatementsAcrossRollback() throws java.sql.SQLException
supportsOpenStatementsAcrossRollback
in interface java.sql.DatabaseMetaData
true
if statements always remain open;
false
if they might not remain open
java.sql.SQLException
- if a database-access error occurs.public boolean supportsOrderByUnrelated() throws java.sql.SQLException
supportsOrderByUnrelated
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsOuterJoins() throws java.sql.SQLException
supportsOuterJoins
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsPositionedDelete() throws java.sql.SQLException
supportsPositionedDelete
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsPositionedUpdate() throws java.sql.SQLException
supportsPositionedUpdate
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSchemasInDataManipulation() throws java.sql.SQLException
supportsSchemasInDataManipulation
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSchemasInIndexDefinitions() throws java.sql.SQLException
supportsSchemasInIndexDefinitions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSchemasInPrivilegeDefinitions() throws java.sql.SQLException
supportsSchemasInPrivilegeDefinitions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSchemasInProcedureCalls() throws java.sql.SQLException
supportsSchemasInProcedureCalls
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSchemasInTableDefinitions() throws java.sql.SQLException
supportsSchemasInTableDefinitions
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSelectForUpdate() throws java.sql.SQLException
supportsSelectForUpdate
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsStoredProcedures() throws java.sql.SQLException
supportsStoredProcedures
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSubqueriesInComparisons() throws java.sql.SQLException
supportsSubqueriesInComparisons
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSubqueriesInExists() throws java.sql.SQLException
EXISTS
expressions.
supportsSubqueriesInExists
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSubqueriesInIns() throws java.sql.SQLException
IN
statements.
supportsSubqueriesInIns
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsSubqueriesInQuantifieds() throws java.sql.SQLException
supportsSubqueriesInQuantifieds
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsTableCorrelationNames() throws java.sql.SQLException
supportsTableCorrelationNames
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsTransactionIsolationLevel(int level) throws java.sql.SQLException
supportsTransactionIsolationLevel
in interface java.sql.DatabaseMetaData
level
- the values are defined in java.sql.Connection
true
if so
java.sql.SQLException
- if a database-access error occurs.Connection
public boolean supportsTransactions() throws java.sql.SQLException
commit
is a noop, and the isolation level is
TRANSACTION_NONE
.
supportsTransactions
in interface java.sql.DatabaseMetaData
true
if transactions are supported
java.sql.SQLException
- if a database-access error occurs.public boolean supportsUnion() throws java.sql.SQLException
supportsUnion
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsUnionAll() throws java.sql.SQLException
supportsUnionAll
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean usesLocalFilePerTable() throws java.sql.SQLException
usesLocalFilePerTable
in interface java.sql.DatabaseMetaData
true
if the database uses a local file for each
table
java.sql.SQLException
- if a database-access error occurs.public boolean usesLocalFiles() throws java.sql.SQLException
usesLocalFiles
in interface java.sql.DatabaseMetaData
true
if so
java.sql.SQLException
- if a database-access error occurs.public boolean supportsResultSetType(int type) throws java.sql.SQLException
JDBC type | SQL Server cursor type | Server load | Description |
TYPE_FORWARD_ONLY | Forward-only, dynamic (fast forward-only, static with useCursors=true ) |
Light | Fast, will read all data (less fast, doesn't read all data with useCursors=true ). Forward only. |
TYPE_SCROLL_INSENSITIVE | Static cursor | Heavy | Only use with CONCUR_READ_ONLY. SQL Server generates a temporary table, so changes made by others are not visible. Scrollable. |
TYPE_SCROLL_SENSITIVE | Keyset cursor | Medium | Others' updates or deletes visible, but not others' inserts. Scrollable. |
TYPE_SCROLL_SENSITIVE + 1 | Dynamic cursor | Heavy | Others' updates, deletes and inserts visible. Scrollable. |
supportsResultSetType
in interface java.sql.DatabaseMetaData
type
- defined in java.sql.ResultSet
true
if so; false
otherwise
java.sql.SQLException
- if a database access error occursConnection
,
supportsResultSetConcurrency(int, int)
public boolean supportsResultSetConcurrency(int type, int concurrency) throws java.sql.SQLException
JDBC concurrency | SQL Server concurrency | Row locks | Description |
CONCUR_READ_ONLY | Read only | No | Read-only. |
CONCUR_UPDATABLE | Optimistic concurrency, updatable | No | Row integrity checked with timestamp comparison or, when not available, value comparison (except text and image fields). |
CONCUR_UPDATABLE+1 | Pessimistic concurrency, updatable | Yes | Row integrity is ensured by locking rows. |
CONCUR_UPDATABLE+2 | Optimistic concurrency, updatable | No | Row integrity checked with value comparison (except text and image fields). |
supportsResultSetConcurrency
in interface java.sql.DatabaseMetaData
type
- defined in java.sql.ResultSet
concurrency
- type defined in java.sql.ResultSet
true
if so; false
otherwise
java.sql.SQLException
- if a database access error occursConnection
,
supportsResultSetType(int)
public boolean ownUpdatesAreVisible(int type) throws java.sql.SQLException
ownUpdatesAreVisible
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if updates are visible for the
result set type; false
otherwise
java.sql.SQLException
- if a database access error occurspublic boolean ownDeletesAreVisible(int type) throws java.sql.SQLException
ownDeletesAreVisible
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if deletes are visible for the
result set type; false
otherwise
java.sql.SQLException
- if a database access error occurspublic boolean ownInsertsAreVisible(int type) throws java.sql.SQLException
ownInsertsAreVisible
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if inserts are visible for the
result set type; false
otherwise
java.sql.SQLException
- if a database access error occurspublic boolean othersUpdatesAreVisible(int type) throws java.sql.SQLException
othersUpdatesAreVisible
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if updates made by others are
visible for the result set type; false
otherwise
java.sql.SQLException
- if a database access error occurspublic boolean othersDeletesAreVisible(int type) throws java.sql.SQLException
othersDeletesAreVisible
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if deletes made by others are
visible for the result set type; false
otherwise
java.sql.SQLException
- if a database access error occurspublic boolean othersInsertsAreVisible(int type) throws java.sql.SQLException
othersInsertsAreVisible
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if inserts made by others are visible
for the result set type; false
otherwise
java.sql.SQLException
- if a database access error occurspublic boolean updatesAreDetected(int type) throws java.sql.SQLException
ResultSet.rowUpdated
.
updatesAreDetected
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if changes are detected by the
result set type; false
otherwise
java.sql.SQLException
- if a database access error occurspublic boolean deletesAreDetected(int type) throws java.sql.SQLException
deletesAreDetected
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if changes are detected by the result set type
java.sql.SQLException
- if a database access error occurspublic boolean insertsAreDetected(int type) throws java.sql.SQLException
insertsAreDetected
in interface java.sql.DatabaseMetaData
type
- ResultSet
type
true
if changes are detected by the result set type
java.sql.SQLException
- if a database access error occurspublic boolean supportsBatchUpdates() throws java.sql.SQLException
supportsBatchUpdates
in interface java.sql.DatabaseMetaData
true
if the driver supports batch updates;
false
otherwise
java.sql.SQLException
- if a database access error occursprivate void setCaseSensitiveFlag() throws java.sql.SQLException
java.sql.SQLException
public java.sql.ResultSet getAttributes(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String typeNamePattern, java.lang.String attributeNamePattern) throws java.sql.SQLException
getAttributes
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public int getDatabaseMajorVersion() throws java.sql.SQLException
getDatabaseMajorVersion
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public int getDatabaseMinorVersion() throws java.sql.SQLException
getDatabaseMinorVersion
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public int getJDBCMajorVersion() throws java.sql.SQLException
getJDBCMajorVersion
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public int getJDBCMinorVersion() throws java.sql.SQLException
getJDBCMinorVersion
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public int getResultSetHoldability() throws java.sql.SQLException
getResultSetHoldability
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public int getSQLStateType() throws java.sql.SQLException
getSQLStateType
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public java.sql.ResultSet getSuperTables(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String tableNamePattern) throws java.sql.SQLException
getSuperTables
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public java.sql.ResultSet getSuperTypes(java.lang.String catalog, java.lang.String schemaPattern, java.lang.String typeNamePattern) throws java.sql.SQLException
getSuperTypes
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public boolean locatorsUpdateCopy() throws java.sql.SQLException
true
if updates are made to a copy of the LOB; returns
false
if LOB updates are made directly to the database.
NOTE: Since SQL Server / Sybase do not support LOB locators as Oracle does (AFAIK);
this method always returns true
.
locatorsUpdateCopy
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public boolean supportsGetGeneratedKeys() throws java.sql.SQLException
true
if getting auto-generated keys is supported after a
statment is executed; returns false
otherwise
supportsGetGeneratedKeys
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public boolean supportsMultipleOpenResults() throws java.sql.SQLException
true
if Callable statements can return multiple result sets;
returns false
if they can only return one result set.
supportsMultipleOpenResults
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public boolean supportsNamedParameters() throws java.sql.SQLException
true
if the database supports named parameters;
returns false
if the database does not support named parameters.
supportsNamedParameters
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public boolean supportsResultSetHoldability(int param) throws java.sql.SQLException
supportsResultSetHoldability
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public boolean supportsSavepoints() throws java.sql.SQLException
true
if savepoints are supported; returns
false
otherwise
supportsSavepoints
in interface java.sql.DatabaseMetaData
java.sql.SQLException
public boolean supportsStatementPooling() throws java.sql.SQLException
true
if the database supports statement pooling;
returns false
otherwise.
supportsStatementPooling
in interface java.sql.DatabaseMetaData
java.sql.SQLException
private static java.lang.String processEscapes(java.lang.String pattern)
pattern
- the pattern to tranform
String
private java.lang.String syscall(java.lang.String catalog, java.lang.String call)
catalog
- the database name or nullcall
- the stored procedure call to format
String
private static void upperCaseColumnNames(JtdsResultSet results) throws java.sql.SQLException
Sybase returns column names in lowecase while the JDBC standard suggests they should be uppercase.
results
- the result set to modify
java.sql.SQLException
private static CachedResultSet createTypeInfoResultSet(JtdsResultSet rs, boolean useLOBs) throws java.sql.SQLException
java.sql.SQLException
private static java.util.Collection getSortedTypes(java.sql.ResultSet rs, boolean useLOBs) throws java.sql.SQLException
java.sql.SQLException
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |