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
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected StringgetNativeDefaultValue(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 voidprocessChange(Database currentModel, Database desiredModel, AddColumnChange change) Processes the addition of a column to a table.protected voidprocessChange(Database currentModel, Database desiredModel, PrimaryKeyChange change) Processes the change of the primary key of a table.protected voidprocessChange(Database currentModel, Database desiredModel, RemoveColumnChange change) Processes the removal of a column from a table.protected voidprocessChange(Database currentModel, Database desiredModel, RemovePrimaryKeyChange change) Processes the removal of a primary key from a table.protected voidprocessTableStructureChanges(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 voidwriteCastExpression(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 voidwriteColumnAutoIncrementStmt(Table table, Column column) Prints that the column is an auto increment column.voidwriteExternalIndexDropStmt(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:
getNativeDefaultValuein classSqlBuilder- Parameters:
column- The column- Returns:
- The native default value
-
writeColumnAutoIncrementStmt
Prints that the column is an auto increment column.- Overrides:
writeColumnAutoIncrementStmtin 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:
getSelectLastIdentityValuesin classSqlBuilder- Parameters:
table- The table- Returns:
- The sql, or
nullif the database does not support this
-
writeExternalIndexDropStmt
Generates the statement to drop a non-embedded index from the database.- Overrides:
writeExternalIndexDropStmtin 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:
writeCastExpressionin 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, allAddPrimaryKeyChangechanges are applied via anALTER TABLE ADD CONSTRAINTstatement.- Overrides:
processTableStructureChangesin 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
-