/**
* @see de.willuhn.sql.version.Update#execute(de.willuhn.sql.version.UpdateProvider)
*/
public void execute(UpdateProvider provider) throws ApplicationException
{
HBCIUpdateProvider myProvider = (HBCIUpdateProvider) provider;
I18N i18n = myProvider.getResources().getI18N();
// Wenn wir eine Tabelle erstellen wollen, muessen wir wissen, welche
// SQL-Dialekt wir sprechen
String driver = HBCIDBService.SETTINGS.getString("database.driver",DBSupportH2Impl.class.getName());
if (driver == null || !driver.equals(DBSupportMySqlImpl.class.getName()))
{
Logger.info("skip update, not needed");
return; // Update nur fuer MySQL noetig
}
try
{
Logger.info("update sql table for update0011");
String sql = "ALTER TABLE version CHANGE name name VARCHAR(255) NOT NULL;\n";
ScriptExecutor.execute(new StringReader(sql),myProvider.getConnection(),myProvider.getProgressMonitor());
myProvider.getProgressMonitor().log(i18n.tr("Tabelle 'version' aktualisiert"));
}
catch (ApplicationException ae)
{
throw ae;
}