All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.dbmaintain.database.impl.DerbyDatabase Maven / Gradle / Ivy

There is a newer version: 2.7.2
Show newest version
/*
 * Copyright DbMaintain.org
 *
 * 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.
 */
package org.dbmaintain.database.impl;

import org.dbmaintain.database.*;

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashSet;
import java.util.Set;

import static org.apache.commons.dbutils.DbUtils.closeQuietly;


/**
 * Implementation of {@link org.dbmaintain.database.Database} for a Derby database.
 * 

* Special thanks to Scott Prater who donated the initial version of the Derby support code. * * @author Scott Prater * @author Tim Ducheyne * @author Filip Neven */ public class DerbyDatabase extends Database { public DerbyDatabase(DatabaseConnection databaseConnection, String customIdentifierQuoteString, StoredIdentifierCase customStoredIdentifierCase) { super(databaseConnection, customIdentifierQuoteString, customStoredIdentifierCase); } /** * @return the database dialect supported by this db support class, not null */ @Override public String getSupportedDatabaseDialect() { return "derby"; } /** * Returns the names of all tables in the database. * * @return The names of all tables in the database */ @Override public Set getTableNames(String schemaName) { return getSQLHandler().getItemsAsStringSet("select t.TABLENAME from SYS.SYSTABLES t, SYS.SYSSCHEMAS s where t.TABLETYPE = 'T' AND t.SCHEMAID = s.SCHEMAID AND s.SCHEMANAME = '" + schemaName + "'", getDataSource()); } /** * Gets the names of all columns of the given table. * * @param tableName The table, not null * @return The names of the columns of the table with the given name */ @Override public Set getColumnNames(String schemaName, String tableName) { return getSQLHandler().getItemsAsStringSet("select c.COLUMNNAME from SYS.SYSCOLUMNS c, SYS.SYSTABLES t, SYS.SYSSCHEMAS s where c.REFERENCEID = t.TABLEID and t.TABLENAME = '" + tableName + "' AND t.SCHEMAID = s.SCHEMAID AND s.SCHEMANAME = '" + schemaName + "'", getDataSource()); } /** * Retrieves the names of all the views in the database schema. * * @return The names of all views in the database */ @Override public Set getViewNames(String schemaName) { return getSQLHandler().getItemsAsStringSet("select t.TABLENAME from SYS.SYSTABLES t, SYS.SYSSCHEMAS s where t.TABLETYPE = 'V' AND t.SCHEMAID = s.SCHEMAID AND s.SCHEMANAME = '" + schemaName + "'", getDataSource()); } /** * Retrieves the names of all the synonyms in the database schema. * * @return The names of all synonyms in the database */ public Set getSynonymNames(String schemaName) { return getSQLHandler().getItemsAsStringSet("select t.TABLENAME from SYS.SYSTABLES t, SYS.SYSSCHEMAS s where t.TABLETYPE = 'A' AND t.SCHEMAID = s.SCHEMAID AND s.SCHEMANAME = '" + schemaName + "'", getDataSource()); } /** * Retrieves the names of all the triggers in the database schema. * * @return The names of all triggers in the database */ @Override public Set getTriggerNames(String schemaName) { return getSQLHandler().getItemsAsStringSet("select t.TRIGGERNAME from SYS.SYSTRIGGERS t, SYS.SYSSCHEMAS s where t.SCHEMAID = s.SCHEMAID AND s.SCHEMANAME = '" + schemaName + "'", getDataSource()); } /** * Gets the names of all identity columns of the given table. *

* todo check, at this moment the PK columns are returned * * @param tableName The table, not null * @return The names of the identity columns of the table with the given name */ @Override public Set getIdentityColumnNames(String schemaName, String tableName) { return getPrimaryKeyColumnNames(schemaName, tableName); } /** * Increments the identity value for the specified identity column on the specified table to the given value. * * @param tableName The table with the identity column, not null * @param identityColumnName The column, not null * @param identityValue The new value */ @Override public void incrementIdentityColumnToValue(String schemaName, String tableName, String identityColumnName, long identityValue) { getSQLHandler().execute("alter table " + qualified(schemaName, tableName) + " alter column " + quoted(identityColumnName) + " RESTART WITH " + identityValue, getDataSource()); } /** * Disables all referential constraints (e.g. foreign keys) on all table in the schema * * @param schemaName The schema, not null */ @Override public void disableReferentialConstraints(String schemaName) { Set tableNames = getTableNames(schemaName); for (String tableName : tableNames) { disableReferentialConstraints(schemaName, tableName); } } // todo refactor (see oracle) protected void disableReferentialConstraints(String schemaName, String tableName) { SQLHandler sqlHandler = getSQLHandler(); Set constraintNames = sqlHandler.getItemsAsStringSet("select c.CONSTRAINTNAME from SYS.SYSCONSTRAINTS c, SYS.SYSTABLES t, SYS.SYSSCHEMAS s where c.TYPE = 'F' AND c.TABLEID = t.TABLEID AND t.TABLENAME = '" + tableName + "' AND t.SCHEMAID = s.SCHEMAID AND s.SCHEMANAME = '" + schemaName + "'", getDataSource()); for (String constraintName : constraintNames) { sqlHandler.execute("alter table " + qualified(schemaName, tableName) + " drop constraint " + quoted(constraintName), getDataSource()); } } /** * Disables all value constraints (e.g. not null) on all tables in the schema * * @param schemaName The schema, not null */ @Override public void disableValueConstraints(String schemaName) { Set tableNames = getTableNames(schemaName); for (String tableName : tableNames) { disableValueConstraints(schemaName, tableName); } } // todo refactor (see oracle) protected void disableValueConstraints(String schemaName, String tableName) { SQLHandler sqlHandler = getSQLHandler(); // disable all check and unique constraints Set constraintNames = sqlHandler.getItemsAsStringSet("select c.CONSTRAINTNAME from SYS.SYSCONSTRAINTS c, SYS.SYSTABLES t, SYS.SYSSCHEMAS s where c.TYPE in ('U', 'C') AND c.TABLEID = t.TABLEID AND t.TABLENAME = '" + tableName + "' AND t.SCHEMAID = s.SCHEMAID AND s.SCHEMANAME = '" + schemaName + "'", getDataSource()); for (String constraintName : constraintNames) { sqlHandler.execute("alter table " + qualified(schemaName, tableName) + " drop constraint " + quoted(constraintName), getDataSource()); } // retrieve the name of the primary key, since we cannot remove the not-null constraint on this column Set primaryKeyColumnNames = getPrimaryKeyColumnNames(schemaName, tableName); // disable all not null constraints Set notNullColumnNames = getNotNullColummnNames(schemaName, tableName); for (String notNullColumnName : notNullColumnNames) { if (primaryKeyColumnNames.contains(notNullColumnName)) { // Do not remove PK constraints continue; } sqlHandler.execute("alter table " + qualified(schemaName, tableName) + " alter column " + quoted(notNullColumnName) + " NULL", getDataSource()); } } /** * Sets the current schema of the database. If a current schema is set, it does not need to be specified * explicitly in the scripts. */ @Override public void setDatabaseDefaultSchema() { getSQLHandler().execute("set schema " + getDefaultSchemaName(), getDataSource()); } /** * Enables or disables the setting of identity value in insert and update statements. * By default some databases do not allow to set values of identity columns directly from insert/update * statements. If supported, this method will enable/disable this behavior. * * @param schemaName The schema name, not null * @param tableName The table with the identity column, not null * @param enabled True to enable, false to disable */ @Override public void setSettingIdentityColumnValueEnabled(String schemaName, String tableName, boolean enabled) { // nothing to do // 'generated always' columns do not allow values to be set directly // 'generated by default' allows values to be set directly } /** * Synonyms are supported. * * @return True */ @Override public boolean supportsSynonyms() { return true; } /** * Triggers are supported. * * @return True */ @Override public boolean supportsTriggers() { return true; } /** * Identity columns are supported. * * @return True */ @Override public boolean supportsIdentityColumns() { return true; } /** * Setting the default schema is supported. * * @return True */ @Override public boolean supportsSetDatabaseDefaultSchema() { return true; } /** * Gets the names of all primary columns of the given table. *

* This info is not available in the Derby sys tables. The database meta data is used instead to retrieve it. * * @param schemaName The schema, not null * @param tableName The table, not null * @return The names of the primary key columns of the table with the given name */ protected Set getPrimaryKeyColumnNames(String schemaName, String tableName) { Connection connection = null; ResultSet resultSet = null; try { connection = getDataSource().getConnection(); DatabaseMetaData databaseMetaData = connection.getMetaData(); resultSet = databaseMetaData.getPrimaryKeys(null, schemaName, tableName); Set result = new HashSet(); while (resultSet.next()) { result.add(resultSet.getString(4)); // COLUMN_NAME } return result; } catch (SQLException e) { throw new DatabaseException("Unable to get primary key column names for schema name: " + schemaName + ", table name: " + tableName, e); } finally { closeQuietly(connection, null, resultSet); } } /** * Returns the names of all columns that have a 'not-null' constraint on them. *

* This info is not available in the Derby sys tables. The database meta data is used instead to retrieve it. * * @param schemaName The schema, not null * @param tableName The table, not null * @return The set of column names, not null */ protected Set getNotNullColummnNames(String schemaName, String tableName) { Connection connection = null; ResultSet resultSet = null; try { connection = getDataSource().getConnection(); DatabaseMetaData databaseMetaData = connection.getMetaData(); resultSet = databaseMetaData.getColumns(null, schemaName, tableName, "%"); Set result = new HashSet(); while (resultSet.next()) { if (resultSet.getInt(11) == DatabaseMetaData.columnNoNulls) { // NULLABLE result.add(resultSet.getString(4)); //COLUMN_NAME } } return result; } catch (SQLException e) { throw new DatabaseException("Unable to get not null column names for schema name: " + schemaName + ", table name: " + tableName, e); } finally { closeQuietly(connection, null, resultSet); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy