net.java.ao.db
Class ClientDerbyDatabaseProvider

java.lang.Object
  extended by net.java.ao.DatabaseProvider
      extended by net.java.ao.db.ClientDerbyDatabaseProvider
All Implemented Interfaces:
Disposable

public class ClientDerbyDatabaseProvider
extends DatabaseProvider

Author:
Daniel Spiewak

Nested Class Summary
 
Nested classes/interfaces inherited from class net.java.ao.DatabaseProvider
DatabaseProvider.RenderFieldOptions, DatabaseProvider.SqlListener
 
Field Summary
 
Fields inherited from class net.java.ao.DatabaseProvider
logger, sqlLogger, typeManager
 
Constructor Summary
ClientDerbyDatabaseProvider(DisposableDataSource dataSource)
           
 
Method Summary
protected  java.util.Set<java.lang.String> getReservedWords()
          Retrieves the set of all reserved words for the underlying database.
 java.sql.ResultSet getTables(java.sql.Connection conn)
          Returns a result set of all of the tables (and associated meta) in the database.
 java.lang.Object handleBlob(java.sql.ResultSet res, java.lang.Class<?> type, java.lang.String field)
           
 boolean isCaseSensitive()
          Flag indicating whether or not the underlying database uses case-sensitive identifiers.
 java.lang.Object parseValue(int type, java.lang.String value)
          Parses the database-agnostic String value relevant to the specified SQL type in int form (as defined by Types and returns the Java value which corresponds.
protected  java.lang.Iterable<SQLAction> renderAlterTableChangeColumn(NameConverters nameConverters, DDLTable table, DDLField oldField, DDLField field)
          Generates the database-specific DDL statements required to change the given column from its old specification to the given DDL value.
protected  java.lang.Iterable<SQLAction> renderAlterTableDropColumn(NameConverters nameConverters, DDLTable table, DDLField field)
          Generates the database-specific DDL statements required to remove the specified column from the given table.
protected  java.lang.String renderAutoIncrement()
          Generates the DDL fragment required to specify an INTEGER field as auto-incremented.
protected  SQLAction renderDropIndex(IndexNameConverter indexNameConverter, DDLIndex index)
          Generates the database-specific DDL statement required to drop an index.
protected  java.lang.String renderQueryLimit(Query query)
          Renders the LIMIT portion of the query in the database-specific SQL dialect.
protected  void setPostConnectionProperties(java.sql.Connection conn)
          Called to make any post-creation modifications to a new Connection instance.
 void setQueryResultSetProperties(java.sql.ResultSet res, Query query)
          Allows the provider to set database-specific options on a ResultSet instance prior to its use by the library.
 void setQueryStatementProperties(java.sql.Statement stmt, Query query)
          Allows the provider to set database-specific options on a Statement instance prior to its usage in a SELECT query.
 
Methods inherited from class net.java.ao.DatabaseProvider
_getFunctionNameForField, _getTriggerNameForField, _renderDropFunctionForField, _renderDropSequenceForField, _renderDropTriggerForField, _renderFunctionForField, _renderSequenceForField, _renderTriggerForField, addSqlListener, commitTransaction, convertTypeToString, dispose, executeInsertReturningKey, executeUpdate, executeUpdateForAction, executeUpdatesForActions, findForeignKeysForField, getConnection, getDateFormat, getExistingIndexName, getImportedKeys, getIndexes, getMaxIDLength, getSchema, getSequences, getTypeManager, handleUpdateError, hasIndex, hasIndex, insertReturningKey, isNumericType, isSchemaNotEmpty, onSql, preparedStatement, preparedStatement, preparedStatement, processID, processOnClause, processOrderClause, processWhereClause, putBoolean, putNull, querySelectFields, queryTableName, quote, removeSqlListener, renderAccessories, renderAccessoriesForField, renderAction, renderAlterTableAddColumn, renderAlterTableAddColumnStatement, renderAlterTableAddKey, renderAlterTableChangeColumnStatement, renderAlterTableDropColumnStatement, renderAlterTableDropKey, renderAppend, renderConstraintsForTable, renderCreateIndex, renderDate, renderDropAccessories, renderDropAccessoriesForField, renderDropColumnActions, renderDropTableStatement, renderField, renderFieldDefault, renderFieldOptionsInAlterColumn, renderFields, renderFieldType, renderForeignKey, renderInsert, renderPrimaryKey, renderQuery, renderQueryGroupBy, renderQueryJoins, renderQueryOrderBy, renderQuerySelect, renderQueryWhere, renderTable, renderUnique, renderValue, rollbackTransaction, shorten, shouldQuoteID, startTransaction, withSchema
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

ClientDerbyDatabaseProvider

public ClientDerbyDatabaseProvider(DisposableDataSource dataSource)
Method Detail

setPostConnectionProperties

protected void setPostConnectionProperties(java.sql.Connection conn)
                                    throws java.sql.SQLException
Description copied from class: DatabaseProvider
Called to make any post-creation modifications to a new Connection instance. This is used for databases such as Derby which require the schema to be set after the connection is created.

Parameters:
conn - The connection to modify according to the database requirements.
Throws:
java.sql.SQLException

setQueryStatementProperties

public void setQueryStatementProperties(java.sql.Statement stmt,
                                        Query query)
                                 throws java.sql.SQLException
Description copied from class: DatabaseProvider

Allows the provider to set database-specific options on a Statement instance prior to its usage in a SELECT query. This is to allow things like emulation of the LIMIT feature on databases which don't support it within the SQL implementation.

This method is only called on SELECTs.

Overrides:
setQueryStatementProperties in class DatabaseProvider
Parameters:
stmt - The instance against which the properties should be set.
query - The query which is being executed against the statement instance.
Throws:
java.sql.SQLException

setQueryResultSetProperties

public void setQueryResultSetProperties(java.sql.ResultSet res,
                                        Query query)
                                 throws java.sql.SQLException
Description copied from class: DatabaseProvider
Allows the provider to set database-specific options on a ResultSet instance prior to its use by the library. This allows for features such as row offsetting even on databases that don't support it (such as Oracle, Derby, etc).

Overrides:
setQueryResultSetProperties in class DatabaseProvider
Parameters:
res - The ResultSet to modify.
query - The query instance which was run to produce the result set.
Throws:
java.sql.SQLException

getTables

public java.sql.ResultSet getTables(java.sql.Connection conn)
                             throws java.sql.SQLException
Description copied from class: DatabaseProvider

Returns a result set of all of the tables (and associated meta) in the database. The fields of the result set must correspond with those specified in the DatabaseMetaData#getTables(String, String, String, String[]) method. In fact, the default implementation merely calls this method passing (null, null, "", null). For databases (such as PostgreSQL) where this is unsuitable, different parameters can be specified to the getTables method in the override, or an entirely new implementation written, as long as the result set corresponds in fields to the JDBC spec.

Overrides:
getTables in class DatabaseProvider
Parameters:
conn - The connection to use in retrieving the database tables.
Returns:
A result set of tables (and meta) corresponding in fields to the JDBC specification.
Throws:
java.sql.SQLException
See Also:
DatabaseMetaData.getTables(String, String, String, String[])

parseValue

public java.lang.Object parseValue(int type,
                                   java.lang.String value)
Description copied from class: DatabaseProvider

Parses the database-agnostic String value relevant to the specified SQL type in int form (as defined by Types and returns the Java value which corresponds. This method is completely database-agnostic, as are all of all of its delegate methods.

WARNING: This method is being considered for removal to another class (perhaps TypeManager?) as it is not a database-specific function and thus confuses the purpose of this class. Do not rely upon it heavily. (better yet, don't rely on it at all from external code. It's not designed to be part of the public API)

Overrides:
parseValue in class DatabaseProvider
Parameters:
type - The JDBC integer type of the database field against which to parse the value.
value - The database-agnostic String value to parse into a proper Java object with respect to the specified SQL type.
Returns:
A Java value which corresponds to the specified String.

renderQueryLimit

protected java.lang.String renderQueryLimit(Query query)
Description copied from class: DatabaseProvider

Renders the LIMIT portion of the query in the database-specific SQL dialect. There is wide variety in database implementations of this particular SQL clause. In fact, many database do not support it at all.

Unfortunately, we live in the real world of proprietary database implementations that requires us to use database specific keywords or semantics to achieve these outcomes. Appropriate methods should be overridden in such cases.

An example return value: " LIMIT 10,2"

There is usually no need to call this method directly. Under normal operations it functions as a delegate for DatabaseProvider.renderQuery(Query, TableNameConverter, boolean).

Overrides:
renderQueryLimit in class DatabaseProvider
Parameters:
query - The Query instance from which to determine the LIMIT properties.
Returns:
The database-specific SQL rendering of the LIMIT portion of the query.

renderAutoIncrement

protected java.lang.String renderAutoIncrement()
Description copied from class: DatabaseProvider

Generates the DDL fragment required to specify an INTEGER field as auto-incremented. For databases which do not support such flags (which is just about every database exception MySQL), "" is an acceptable return value. This method should never return null as it would cause the field rendering method to throw a NullPointerException.

Overrides:
renderAutoIncrement in class DatabaseProvider

handleBlob

public java.lang.Object handleBlob(java.sql.ResultSet res,
                                   java.lang.Class<?> type,
                                   java.lang.String field)
                            throws java.sql.SQLException
Overrides:
handleBlob in class DatabaseProvider
Throws:
java.sql.SQLException

renderAlterTableChangeColumn

protected java.lang.Iterable<SQLAction> renderAlterTableChangeColumn(NameConverters nameConverters,
                                                                     DDLTable table,
                                                                     DDLField oldField,
                                                                     DDLField field)
Description copied from class: DatabaseProvider

Generates the database-specific DDL statements required to change the given column from its old specification to the given DDL value. This method will also generate the appropriate statements to remove old triggers and functions, as well as add new ones according to the requirements of the new field definition.

The default implementation of this method functions in the manner specified by the MySQL database. Some databases will have to perform more complicated actions (such as dropping and re-adding the field) in order to satesfy the same use-case. Such databases should print a warning to stderr to ensure that the end-developer is aware of such restrictions.

Thus, the specification for this method allows for data loss. Nevertheless, if the database supplies a mechanism to accomplish the task without data loss, it should be applied.

For maximum flexibility, the default implementation of this method only deals with the dropping and addition of functions and triggers. The actual generation of the ALTER TABLE statement is done in the DatabaseProvider.renderAlterTableChangeColumnStatement(net.java.ao.schema.NameConverters, net.java.ao.schema.ddl.DDLTable, net.java.ao.schema.ddl.DDLField, net.java.ao.schema.ddl.DDLField, net.java.ao.DatabaseProvider.RenderFieldOptions) method.

Overrides:
renderAlterTableChangeColumn in class DatabaseProvider
table - The table containing the column to change.
oldField - The old column definition.
field - The new column definition (defining the resultant DDL). @return An array of DDL statements to be executed.
See Also:
#getTriggerNameForField(net.java.ao.schema.TriggerNameConverter, net.java.ao.schema.ddl.DDLTable, net.java.ao.schema.ddl.DDLField), #getFunctionNameForField(net.java.ao.schema.TriggerNameConverter, net.java.ao.schema.ddl.DDLTable, net.java.ao.schema.ddl.DDLField), #renderFunctionForField(net.java.ao.schema.TriggerNameConverter, net.java.ao.schema.ddl.DDLTable, net.java.ao.schema.ddl.DDLField), #renderTriggerForField(net.java.ao.schema.TriggerNameConverter, net.java.ao.schema.SequenceNameConverter, net.java.ao.schema.ddl.DDLTable, net.java.ao.schema.ddl.DDLField)

renderAlterTableDropColumn

protected java.lang.Iterable<SQLAction> renderAlterTableDropColumn(NameConverters nameConverters,
                                                                   DDLTable table,
                                                                   DDLField field)
Description copied from class: DatabaseProvider
Generates the database-specific DDL statements required to remove the specified column from the given table. This should also generate the necessary statements to drop all triggers and functions associated with the column in question. If the database being implemented has a non-standard syntax for dropping functions and/or triggers, it may be required to override this method, even if the syntax to drop columns is standard.

Overrides:
renderAlterTableDropColumn in class DatabaseProvider
table - The table from which to drop the column.
field - The column definition to remove from the table.
Returns:
An array of DDL statements to be executed.
See Also:
#getTriggerNameForField(net.java.ao.schema.TriggerNameConverter, net.java.ao.schema.ddl.DDLTable, net.java.ao.schema.ddl.DDLField), #getFunctionNameForField(net.java.ao.schema.TriggerNameConverter, net.java.ao.schema.ddl.DDLTable, net.java.ao.schema.ddl.DDLField)

renderDropIndex

protected SQLAction renderDropIndex(IndexNameConverter indexNameConverter,
                                    DDLIndex index)
Description copied from class: DatabaseProvider
Generates the database-specific DDL statement required to drop an index. The syntax for this operation is highly standardized and thus it is unlikely this method will be overridden. If the database in question does not support indexes, a warning should be printed to stderr and null returned.

Overrides:
renderDropIndex in class DatabaseProvider
index - The index to drop. This single instance contains all of the data necessary to drop the index, thus no separate parameters (such as a DDLTable) are required.
Returns:
A DDL statement to be executed, or null.

getReservedWords

protected java.util.Set<java.lang.String> getReservedWords()
Description copied from class: DatabaseProvider
Retrieves the set of all reserved words for the underlying database. The set returns should be speculative, meaning that it should include any possible reserved words, not just those for a particular version. As an implementation guideline, the Set instance returned from this method should guarentee O(1) lookup times, otherwise ORM performance will suffer greatly.

Specified by:
getReservedWords in class DatabaseProvider
Returns:
A set of upper case reserved words specific to the database.

isCaseSensitive

public boolean isCaseSensitive()
Description copied from class: DatabaseProvider
Flag indicating whether or not the underlying database uses case-sensitive identifiers. This specifically affects comparisons in the SchemaReader utility. The default value is true. Note that databases which support both case-sensetive and case-insensetive identifiers (like MySQL) should return true for better all-around compatibility.

Overrides:
isCaseSensitive in class DatabaseProvider
Returns:
boolean true if identifiers are case-sensetive, false otherwise.


Copyright © 2007-2014. All Rights Reserved.