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

org.apache.openjpa.jdbc.schema.Constraint Maven / Gradle / Ivy

There is a newer version: 4.0.1
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.apache.openjpa.jdbc.schema;

import org.apache.openjpa.jdbc.identifier.DBIdentifier;
import org.apache.openjpa.jdbc.identifier.QualifiedDBIdentifier;

/**
 * A table constraint. This class is closely aligned with the constraint
 * information available from {@link java.sql.DatabaseMetaData}.
 *
 * @author Abe White
 */
public abstract class Constraint extends ReferenceCounter {
    private static final long serialVersionUID = 1L;
    private DBIdentifier _name = DBIdentifier.NULL;
    private QualifiedDBIdentifier _fullPath = null;
    private Table _table = null;
    private DBIdentifier _tableName = DBIdentifier.NULL;
    private DBIdentifier _schemaName = DBIdentifier.NULL;
    private DBIdentifier _columnName = DBIdentifier.NULL;
    private boolean _deferred = false;

    /**
     * Default constructor.
     */
    Constraint() {
    }

    /**
     * Constructor.
     *
     * @param name the name of the constraint, or null if none
     * @param table the local table of the constraint
     * @deprecated
     */
    @Deprecated
    Constraint(String name, Table table) {
        this(DBIdentifier.newConstant(name), table);
    }

    Constraint(DBIdentifier name, Table table) {
        setIdentifier(name);
        if (table != null) {
            setTableIdentifier(table.getIdentifier());
            setSchemaIdentifier(table.getSchemaIdentifier());
        }
        _table = table;
    }

    /**
     * Called when the constraint is removed from the owning table.
     * Invalidates the constraint.
     */
    void remove() {
        _table = null;
    }

    /**
     * Return the table of this constraint.
     */
    public Table getTable() {
        return _table;
    }

    /**
     * Return the column's table name.
     * @deprecated
     */
    @Deprecated
    public String getTableName() {
        return getTableIdentifier().getName();
    }

    public DBIdentifier getTableIdentifier() {
        return _tableName == null ? DBIdentifier.NULL : _tableName;
    }

    /**
     * Set the column's table name. You can only call this method on
     * columns whose table object is not set.
     * @deprecated
     */
    @Deprecated
    public void setTableName(String name) {
        setTableIdentifier(DBIdentifier.newTable(name));
    }

      public void setTableIdentifier(DBIdentifier name) {
          if (getTable() != null)
              throw new IllegalStateException();
          _tableName = name;
          _fullPath = null;
      }


    /**
     * Return the column table's schema name.
     * @deprecated
     */
    @Deprecated
    public String getSchemaName() {
        return getSchemaIdentifier().getName();
    }

    public DBIdentifier getSchemaIdentifier() {
        return _schemaName == null ? DBIdentifier.NULL : _schemaName;
    }

    /**
     * Set the column table's schema name. You can only call this method on
     * columns whose table object is not set.
     * @deprecated
     */
    @Deprecated
    public void setSchemaName(String schema) {
        setSchemaIdentifier(DBIdentifier.newSchema(schema));
    }

    public void setSchemaIdentifier(DBIdentifier schema) {
        if (getTable() != null)
            throw new IllegalStateException();
        _schemaName = schema;
    }

    /**
     * Return the column's name.
     * @deprecated
     */
    @Deprecated
    public String getColumnName() {
        return getColumnIdentifier().getName();
    }

    public DBIdentifier getColumnIdentifier() {
        return _columnName == null ? DBIdentifier.NULL : _columnName;
    }

    /**
     * Set the column's name. You can only call this method on
     * columns whose table object is not set.
     * @deprecated
     */
    @Deprecated
    public void setColumnName(String name) {
        setColumnIdentifier(DBIdentifier.newColumn(name));
    }

    public void setColumnIdentifier(DBIdentifier name) {
        if (getTable() != null)
            throw new IllegalStateException();
        _columnName = name;
    }

    /**
     * Return the name of the constraint.
     * @deprecated
     */
    @Deprecated
    public String getName() {
        return getIdentifier().getName();
    }

    public DBIdentifier getIdentifier() {
        return _name == null ? DBIdentifier.NULL : _name;
    }


    /**
     * Set the name of the constraint. This method cannot be called if the
     * constraint already belongs to a table.
     * @deprecated
     */
    @Deprecated
    public void setName(String name) {
        setIdentifier(DBIdentifier.newConstraint(name));
    }

    public void setIdentifier(DBIdentifier name) {
        if (getTable() != null)
            throw new IllegalStateException();
        _name = name;
        _fullPath = null;
    }

    /**
     * Return the full name of the constraint.
     * @deprecated
     */
    @Deprecated
    public String getFullName() {
        return getFullIdentifier().getName();
    }

    public QualifiedDBIdentifier getQualifiedPath() {
        if (_fullPath == null) {
            _fullPath = QualifiedDBIdentifier.newPath(getTableIdentifier(), getIdentifier());
        }
        return _fullPath;
    }

    public DBIdentifier getFullIdentifier() {
        return getQualifiedPath().getIdentifier();
    }


    /**
     * Return whether this constraint is a logical constraint only; i.e.
     * if it does not exist in the database.
     */
    public abstract boolean isLogical();

    /**
     * Return true if this is a deferred constraint.
     */
    public boolean isDeferred() {
        return _deferred;
    }

    /**
     * Make this constrain deferred.
     */
    public void setDeferred(boolean deferred) {
        _deferred = deferred;
    }

    @Override
    public String toString() {
        if (!getIdentifier().isNull())
            return getIdentifier().getName();

        String name = getClass().getName();
        name = name.substring(name.lastIndexOf('.') + 1);
        return "<" + name.toLowerCase() + ">";
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;

        Constraint that = (Constraint) o;

        if (_deferred != that._deferred) return false;
        if (_name != null ? !_name.equals(that._name) : that._name != null) return false;
        if (_fullPath != null ? !_fullPath.equals(that._fullPath) : that._fullPath != null) return false;
        if (_table != null ? !_table.equals(that._table) : that._table != null) return false;
        if (_tableName != null ? !_tableName.equals(that._tableName) : that._tableName != null) return false;
        if (_schemaName != null ? !_schemaName.equals(that._schemaName) : that._schemaName != null) return false;
        return _columnName != null ? _columnName.equals(that._columnName) : that._columnName == null;
    }

    @Override
    public int hashCode() {
        int result = _name != null ? _name.hashCode() : 0;
        result = 31 * result + (_fullPath != null ? _fullPath.hashCode() : 0);
        result = 31 * result + (_table != null ? _table.hashCode() : 0);
        result = 31 * result + (_tableName != null ? _tableName.hashCode() : 0);
        result = 31 * result + (_schemaName != null ? _schemaName.hashCode() : 0);
        result = 31 * result + (_columnName != null ? _columnName.hashCode() : 0);
        result = 31 * result + (_deferred ? 1 : 0);
        return result;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy