liquibase.ext.percona.PerconaAddColumnChange Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of liquibase-percona Show documentation
Show all versions of liquibase-percona Show documentation
A Liquibase extension that makes use of the percona toolkit
package liquibase.ext.percona;
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.util.ArrayList;
import java.util.List;
import liquibase.change.AddColumnConfig;
import liquibase.change.Change;
import liquibase.change.ChangeMetaData;
import liquibase.change.ColumnConfig;
import liquibase.change.DatabaseChange;
import liquibase.change.core.AddColumnChange;
import liquibase.change.core.DropDefaultValueChange;
import liquibase.database.Database;
import liquibase.datatype.DataTypeFactory;
import liquibase.statement.SqlStatement;
/**
* Subclasses the original {@link liquibase.change.core.AddColumnChange} to
* integrate with pt-online-schema-change.
* @see PTOnlineSchemaChangeStatement
*/
@DatabaseChange(name = PerconaAddColumnChange.NAME, description = "Adds a new column to an existing table",
priority = PerconaAddColumnChange.PRIORITY, appliesTo = "table")
public class PerconaAddColumnChange extends AddColumnChange {
public static final String NAME= "addColumn";
public static final int PRIORITY = ChangeMetaData.PRIORITY_DEFAULT + 50;
/**
* Generates the statements required for the add column change.
* In case of a MySQL database, percona toolkit will be used.
* In case of generating the SQL statements for review (updateSQL) the command
* will be added as a comment.
* @param database the database
* @return the list of statements
* @see PTOnlineSchemaChangeStatement
*/
@Override
public SqlStatement[] generateStatements(Database database) {
return PerconaChangeUtil.generateStatements(PerconaAddColumnChange.NAME,
database,
super.generateStatements(database),
getTableName(),
generateAlterStatement(database));
}
String generateAlterStatement(Database database) {
StringBuilder alter = new StringBuilder();
boolean firstColumn = true;
for (AddColumnConfig a : getColumns()) {
if (!firstColumn) {
alter.append(", ");
}
alter.append(convertColumnToSql(a, database));
firstColumn = false;
}
return alter.toString();
}
String convertColumnToSql(AddColumnConfig column, Database database) {
String nullable = "";
if (column.getConstraints() != null && !column.getConstraints().isNullable()) {
nullable = " NOT NULL";
} else {
nullable = " NULL";
}
String defaultValue = "";
if (column.getDefaultValueObject() != null) {
defaultValue = " DEFAULT " + DataTypeFactory.getInstance().fromObject(column.getDefaultValueObject(), database).objectToSql(column.getDefaultValueObject(), database);
}
String comment = "";
if (column.getRemarks() != null) {
comment += " COMMENT '" + column.getRemarks() + "'";
}
return "ADD COLUMN " + database.escapeColumnName(null, null, null, column.getName())
+ " " + DataTypeFactory.getInstance().fromDescription(column.getType(), database).toDatabaseDataType(database)
+ nullable
+ defaultValue
+ comment;
}
@Override
protected Change[] createInverses() {
List inverses = new ArrayList();
for (ColumnConfig aColumn : getColumns()) {
if (aColumn.hasDefaultValue()) {
DropDefaultValueChange dropChange = new DropDefaultValueChange();
dropChange.setTableName(getTableName());
dropChange.setColumnName(aColumn.getName());
dropChange.setSchemaName(getSchemaName());
inverses.add(dropChange);
}
// that's the percona drop column change.
PerconaDropColumnChange inverse = new PerconaDropColumnChange();
inverse.setSchemaName(getSchemaName());
inverse.setColumnName(aColumn.getName());
inverse.setTableName(getTableName());
inverses.add(inverse);
}
return inverses.toArray(new Change[inverses.size()]);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy