Skip to content

Commit

Permalink
HHH-12271 - SchemaDropperImpl does not drop constraints with IF EXISTS
Browse files Browse the repository at this point in the history
  • Loading branch information
dreab8 committed Feb 5, 2018
1 parent 84c5085 commit da51a0d
Showing 1 changed file with 23 additions and 10 deletions.
Expand Up @@ -21,7 +21,7 @@
* @author Steve Ebersole
*/
public class StandardForeignKeyExporter implements Exporter<ForeignKey> {
private static final String COLUMN_MISMATCH_MSG = "Number of referencing columns [%s] did not " +
private static final String COLUMN_MISMATCH_MSG = "Number of referencing columns [%s] did not " +
"match number of referenced columns [%s] in foreign-key [%s] from [%s] to [%s]";

private final Dialect dialect;
Expand All @@ -32,11 +32,11 @@ public StandardForeignKeyExporter(Dialect dialect) {

@Override
public String[] getSqlCreateStrings(ForeignKey foreignKey, Metadata metadata) {
if ( ! dialect.hasAlterTable() ) {
if ( !dialect.hasAlterTable() ) {
return NO_COMMANDS;
}
if ( ! foreignKey.isCreationEnabled() ) {

if ( !foreignKey.isCreationEnabled() ) {
return NO_COMMANDS;
}

Expand All @@ -45,8 +45,8 @@ public String[] getSqlCreateStrings(ForeignKey foreignKey, Metadata metadata) {
}

final int numberOfColumns = foreignKey.getColumnSpan();
final String[] columnNames = new String[ numberOfColumns ];
final String[] targetColumnNames = new String[ numberOfColumns ];
final String[] columnNames = new String[numberOfColumns];
final String[] targetColumnNames = new String[numberOfColumns];

final Iterator targetItr;
if ( foreignKey.isReferenceToPrimaryKey() ) {
Expand Down Expand Up @@ -127,11 +127,11 @@ public String[] getSqlCreateStrings(ForeignKey foreignKey, Metadata metadata) {

@Override
public String[] getSqlDropStrings(ForeignKey foreignKey, Metadata metadata) {
if ( ! dialect.hasAlterTable() ) {
if ( !dialect.hasAlterTable() ) {
return NO_COMMANDS;
}

if ( ! foreignKey.isCreationEnabled() ) {
if ( !foreignKey.isCreationEnabled() ) {
return NO_COMMANDS;
}

Expand All @@ -145,8 +145,21 @@ public String[] getSqlDropStrings(ForeignKey foreignKey, Metadata metadata) {
dialect
);
return new String[] {
dialect.getAlterTableString( sourceTableName )
+ dialect.getDropForeignKeyString() + foreignKey.getName()
getSqlDropStrings( sourceTableName, foreignKey, dialect )
};
}

private String getSqlDropStrings(String tableName, ForeignKey foreignKey, Dialect dialect) {
final StringBuilder buf = new StringBuilder( dialect.getAlterTableString( tableName ) );
buf.append( dialect.getDropForeignKeyString() );
if ( dialect.supportsIfExistsBeforeConstraintName() ) {
buf.append( "if exists " );
}
buf.append( dialect.quote( foreignKey.getName() ) );
if ( dialect.supportsIfExistsAfterConstraintName() ) {
buf.append( " if exists" );
}
return buf.toString();
}

}

0 comments on commit da51a0d

Please sign in to comment.