package com.tesora.dve.upgrade.versions;
/*
* #%L
* Tesora Inc.
* Database Virtualization Engine
* %%
* Copyright (C) 2011 - 2014 Tesora Inc.
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License, version 3,
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
* #L%
*/
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.lang.BooleanUtils;
import com.tesora.dve.charset.NativeCollation;
import com.tesora.dve.charset.MysqlNativeCollationCatalog;
import com.tesora.dve.common.DBHelper;
import com.tesora.dve.common.InformationCallback;
import com.tesora.dve.exceptions.PEException;
public class AddCollation extends SimpleCatalogVersion {
public AddCollation(int version) {
super(version);
}
@Override
public String[] getUpgradeCommands(DBHelper helper) throws PEException {
return new String[] {
"alter table character_sets drop column default_collate_name",
"create table collations (name varchar(32) not null, character_set_name varchar(32) not null, id integer not null, is_default integer not null default '0', is_compiled integer not null default '1', sortlen bigint(3) not null, primary key(id)) ENGINE=InnoDB;"
};
}
@Override
public void upgrade(DBHelper helper, InformationCallback stdout) throws PEException {
super.upgrade(helper, stdout);
try {
List<Object> params = new ArrayList<Object>();
helper.prepare("insert into collations (id, name, character_set_name, is_default, is_compiled, sortlen) values (?,?,?,?,?,?)");
for(String collationName : MysqlNativeCollationCatalog.DEFAULT_CATALOG.getCollationsCatalogEntriesByName()) {
NativeCollation nc = MysqlNativeCollationCatalog.DEFAULT_CATALOG.findCollationByName(collationName);
params.clear();
params.add(nc.getId());
params.add(nc.getName());
params.add(nc.getCharacterSetName());
params.add(BooleanUtils.toInteger(nc.isDefault()));
params.add(BooleanUtils.toInteger(nc.isCompiled()));
params.add(nc.getSortLen());
helper.executePrepared(params);
}
} catch (SQLException sqle) {
throw new PEException("Unable to insert collation values: " + sqle.getMessage());
}
}
}