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

schemacrawler.crawl.MutableForeignKey Maven / Gradle / Ivy

Go to download

SchemaCrawler is an open-source Java API that makes working with database metadata as easy as working with plain old Java objects. SchemaCrawler is also a database schema discovery and comprehension, and schema documentation tool. You can search for database schema objects using regular expressions, and output the schema and data in a readable text format. The output is designed to be diff-ed against other database schemas.

There is a newer version: 16.25.2
Show newest version
/*
========================================================================
SchemaCrawler
http://www.schemacrawler.com
Copyright (c) 2000-2016, Sualeh Fatehi .
All rights reserved.
------------------------------------------------------------------------

SchemaCrawler 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.

SchemaCrawler and the accompanying materials are made available under
the terms of the Eclipse Public License v1.0, GNU General Public License
v3 or GNU Lesser General Public License v3.

You may elect to redistribute this code under any of these licenses.

The Eclipse Public License is available at:
http://www.eclipse.org/legal/epl-v10.html

The GNU General Public License v3 and the GNU Lesser General Public
License v3 are available at:
http://www.gnu.org/licenses/

========================================================================
*/

package schemacrawler.crawl;


import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.SortedSet;
import java.util.TreeSet;

import schemacrawler.schema.BaseForeignKey;
import schemacrawler.schema.Column;
import schemacrawler.schema.ColumnReference;
import schemacrawler.schema.ForeignKey;
import schemacrawler.schema.ForeignKeyColumnReference;
import schemacrawler.schema.ForeignKeyDeferrability;
import schemacrawler.schema.ForeignKeyUpdateRule;
import schemacrawler.schema.NamedObject;
import schemacrawler.schema.TableConstraintType;
import schemacrawler.utility.CompareUtility;

/**
 * Represents a foreign-key mapping to a primary key in another table.
 *
 * @author Sualeh Fatehi
 */
final class MutableForeignKey
  extends AbstractNamedObjectWithAttributes
  implements ForeignKey
{

  private static final long serialVersionUID = 4121411795974895671L;

  private final SortedSet columnReferences = new TreeSet<>();

  private ForeignKeyUpdateRule updateRule;
  private ForeignKeyUpdateRule deleteRule;
  private ForeignKeyDeferrability deferrability;
  private Boolean deferrable; // initialize to null
  private Boolean initiallyDeferred; // initialize to null
  private final StringBuilder definition;

  MutableForeignKey(final String name)
  {
    super(name);

    definition = new StringBuilder();

    // Default values
    updateRule = ForeignKeyUpdateRule.unknown;
    deleteRule = ForeignKeyUpdateRule.unknown;
    deferrability = ForeignKeyDeferrability.unknown;
  }

  /**
   * {@inheritDoc}
   * 

* Note: Since foreign keys are not always explicitly named in * databases, the sorting routine orders the foreign keys by the names * of the columns in the foreign keys. *

*/ @Override public int compareTo(final NamedObject obj) { if (obj == null) { return -1; } final BaseForeignKey other = (BaseForeignKey) obj; final List thisColumnReferences = getColumnReferences(); final List otherColumnReferences = other .getColumnReferences(); return CompareUtility.compareLists(thisColumnReferences, otherColumnReferences); } /** * {@inheritDoc} * * @see ForeignKey#getColumnReferences() */ @Override public List getColumnReferences() { return new ArrayList(columnReferences); } @Override public TableConstraintType getConstraintType() { return TableConstraintType.foreign_key; } /** * {@inheritDoc} * * @see ForeignKey#getDeferrability() */ @Override public final ForeignKeyDeferrability getDeferrability() { return deferrability; } /** * {@inheritDoc} * * @see ForeignKey#getDefinition() */ @Override public String getDefinition() { return definition.toString(); } /** * {@inheritDoc} * * @see ForeignKey#getDeleteRule() */ @Override public final ForeignKeyUpdateRule getDeleteRule() { return deleteRule; } /** * {@inheritDoc} * * @see ForeignKey#getUpdateRule() */ @Override public final ForeignKeyUpdateRule getUpdateRule() { return updateRule; } @Override public boolean hasDefinition() { return definition.length() > 0; } @Override public boolean isDeferrable() { if (deferrable == null) { throw new NotLoadedException(this); } return deferrable; } @Override public boolean isInitiallyDeferred() { if (initiallyDeferred == null) { throw new NotLoadedException(this); } return initiallyDeferred; } @Override public Iterator iterator() { return new ArrayList(columnReferences) .iterator(); } void addColumnReference(final int keySequence, final Column pkColumn, final Column fkColumn) { if (pkColumn != null && fkColumn != null && pkColumn.equals(fkColumn)) { return; } final MutableForeignKeyColumnReference fkColumnReference = new MutableForeignKeyColumnReference(keySequence, pkColumn, fkColumn); columnReferences.add(fkColumnReference); } void appendDefinition(final String definition) { if (definition != null) { this.definition.append(definition); } } final void setDeferrability(final ForeignKeyDeferrability deferrability) { this.deferrability = deferrability; } void setDeferrable(final boolean deferrable) { this.deferrable = deferrable; } final void setDeleteRule(final ForeignKeyUpdateRule deleteRule) { this.deleteRule = deleteRule; } void setInitiallyDeferred(final boolean initiallyDeferred) { this.initiallyDeferred = initiallyDeferred; } final void setUpdateRule(final ForeignKeyUpdateRule updateRule) { this.updateRule = updateRule; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy