Class Db2Builder
java.lang.Object
edu.internet2.middleware.grouper.ext.org.apache.ddlutils.platform.SqlBuilder
edu.internet2.middleware.grouper.ext.org.apache.ddlutils.platform.db2.Db2Builder
- Direct Known Subclasses:
Db2v8Builder
The SQL Builder for DB2.
- Version:
- $Revision: 504811 $
-
Field Summary
Fields inherited from class edu.internet2.middleware.grouper.ext.org.apache.ddlutils.platform.SqlBuilder
_log, SIZE_PLACEHOLDER
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected String
getNativeDefaultValue
(Column column) Returns the native default value for the column.getSelectLastIdentityValues
(Table table) Generates the SQL for querying the id that was created in the last insertion operation.protected void
processChange
(Database currentModel, Database desiredModel, AddColumnChange change) Processes the addition of a column to a table.protected void
processChange
(Database currentModel, Database desiredModel, PrimaryKeyChange change) Processes the change of the primary key of a table.protected void
processChange
(Database currentModel, Database desiredModel, RemoveColumnChange change) Processes the removal of a column from a table.protected void
processChange
(Database currentModel, Database desiredModel, RemovePrimaryKeyChange change) Processes the removal of a primary key from a table.protected void
processTableStructureChanges
(Database currentModel, Database desiredModel, Table sourceTable, Table targetTable, Map parameters, List changes) Allows database-specific implementations to handle changes in a database specific manner.protected void
writeCastExpression
(Column sourceColumn, Column targetColumn) Writes a cast expression that converts the value of the source column to the data type of the target column.protected void
writeColumnAutoIncrementStmt
(Table table, Column column) Prints that the column is an auto increment column.void
writeExternalIndexDropStmt
(Table table, Index index) Generates the statement to drop a non-embedded index from the database.Methods inherited from class edu.internet2.middleware.grouper.ext.org.apache.ddlutils.platform.SqlBuilder
addEscapedCharSequence, alterDatabase, applyForSelectedChanges, areEqual, columnsDiffer, createExternalForeignKeys, createExternalForeignKeys, createTable, createTable, createTables, createTables, createTables, createTemporaryTable, createUniqueIdentifier, dropExternalForeignKeys, dropTable, dropTable, dropTables, dropTemporaryTable, escapeStringValue, findCorrespondingForeignKey, getBareNativeType, getColumnName, getConstraintName, getDefaultValueHelper, getDeleteSql, getDelimitedIdentifier, getForeignKeyName, getIndent, getIndexName, getInsertSql, getMaxColumnNameLength, getMaxConstraintNameLength, getMaxForeignKeyNameLength, getMaxTableNameLength, getNativeType, getPlatform, getPlatformInfo, getRealTargetTableFor, getSqlType, getTableName, getTemporaryTableFor, getUpdateSql, getValueAsString, getValueDateFormat, getValueLocale, getValueNumberFormat, getValueTimeFormat, getWriter, isValidDefaultValue, print, printComment, printDefaultValue, printEndOfStatement, printIdentifier, printIndent, println, println, printlnIdentifier, printStartOfEmbeddedStatement, processChange, processChange, processChange, processChange, processChange, processChange, processChange, processChange, processChanges, processTableStructureChanges, processTableStructureChanges, setIndent, setValueDateFormat, setValueLocale, setValueNumberFormat, setValueTimeFormat, setWriter, shortenName, shouldGeneratePrimaryKeys, writeColumn, writeColumnDefaultValue, writeColumnDefaultValueStmt, writeColumnNotNullableStmt, writeColumnNullableStmt, writeColumns, writeCopyDataStatement, writeEmbeddedForeignKeysStmt, writeEmbeddedIndexCreateStmt, writeEmbeddedIndicesStmt, writeEmbeddedPrimaryKeysStmt, writeExternalForeignKeyCreateStmt, writeExternalForeignKeyDropStmt, writeExternalIndexCreateStmt, writeExternalIndicesCreateStmt, writeExternalPrimaryKeysCreateStmt, writeForeignReferences, writeLocalReferences, writePrimaryKeyStmt, writeTableAlterStmt, writeTableComment, writeTableCreationStmt, writeTableCreationStmtEnding
-
Constructor Details
-
Db2Builder
Creates a new builder instance.- Parameters:
platform
- The plaftform this builder belongs to
-
-
Method Details
-
getNativeDefaultValue
Returns the native default value for the column.- Overrides:
getNativeDefaultValue
in classSqlBuilder
- Parameters:
column
- The column- Returns:
- The native default value
-
writeColumnAutoIncrementStmt
Prints that the column is an auto increment column.- Overrides:
writeColumnAutoIncrementStmt
in classSqlBuilder
- Parameters:
table
- The tablecolumn
- The column- Throws:
IOException
-
getSelectLastIdentityValues
Generates the SQL for querying the id that was created in the last insertion operation. This is obviously only useful for pk fields that are auto-incrementing. A database that does not support this, will returnnull
.- Overrides:
getSelectLastIdentityValues
in classSqlBuilder
- Parameters:
table
- The table- Returns:
- The sql, or
null
if the database does not support this
-
writeExternalIndexDropStmt
Generates the statement to drop a non-embedded index from the database.- Overrides:
writeExternalIndexDropStmt
in classSqlBuilder
- Parameters:
table
- The table the index is onindex
- The index to drop- Throws:
IOException
-
writeCastExpression
Writes a cast expression that converts the value of the source column to the data type of the target column. Per default, simply the name of the source column is written thereby assuming that any casts happen implicitly.- Overrides:
writeCastExpression
in classSqlBuilder
- Parameters:
sourceColumn
- The source columntargetColumn
- The target column- Throws:
IOException
-
processTableStructureChanges
protected void processTableStructureChanges(Database currentModel, Database desiredModel, Table sourceTable, Table targetTable, Map parameters, List changes) throws IOException Allows database-specific implementations to handle changes in a database specific manner. Any handled change should be applied to the given current model (which is a copy of the real original model) and be removed from the list of changes.
In the default implementation, allAddPrimaryKeyChange
changes are applied via anALTER TABLE ADD CONSTRAINT
statement.- Overrides:
processTableStructureChanges
in classSqlBuilder
- Parameters:
currentModel
- The current database schemadesiredModel
- The desired database schemasourceTable
- The original tabletargetTable
- The desired tableparameters
- The creation parameters for the tablechanges
- The change objects for the target table- Throws:
IOException
-
processChange
protected void processChange(Database currentModel, Database desiredModel, AddColumnChange change) throws IOException Processes the addition of a column to a table.- Parameters:
currentModel
- The current database schemadesiredModel
- The desired database schemachange
- The change object- Throws:
IOException
-
processChange
protected void processChange(Database currentModel, Database desiredModel, RemoveColumnChange change) throws IOException Processes the removal of a column from a table.- Parameters:
currentModel
- The current database schemadesiredModel
- The desired database schemachange
- The change object- Throws:
IOException
-
processChange
protected void processChange(Database currentModel, Database desiredModel, RemovePrimaryKeyChange change) throws IOException Processes the removal of a primary key from a table.- Parameters:
currentModel
- The current database schemadesiredModel
- The desired database schemachange
- The change object- Throws:
IOException
-
processChange
protected void processChange(Database currentModel, Database desiredModel, PrimaryKeyChange change) throws IOException Processes the change of the primary key of a table.- Parameters:
currentModel
- The current database schemadesiredModel
- The desired database schemachange
- The change object- Throws:
IOException
-