Package org.apache.derby.iapi.sql.dictionary

Source Code of org.apache.derby.iapi.sql.dictionary.ConstraintDescriptorList

/*

   Derby - Class org.apache.derby.iapi.sql.dictionary.ConstraintDescriptorList

   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.derby.iapi.sql.dictionary;

import org.apache.derby.iapi.error.StandardException;
import org.apache.derby.iapi.services.sanity.SanityManager;

import org.apache.derby.catalog.UUID;

import org.apache.derby.iapi.sql.dictionary.ConstraintDescriptor;
import org.apache.derby.iapi.sql.dictionary.ReferencedKeyConstraintDescriptor;
import org.apache.derby.iapi.sql.dictionary.DataDictionary;
import org.apache.derby.iapi.sql.dictionary.KeyConstraintDescriptor;
import org.apache.derby.iapi.sql.dictionary.SchemaDescriptor;

import org.apache.derby.iapi.error.StandardException;
import org.apache.derby.iapi.services.sanity.SanityManager;

import org.apache.derby.catalog.UUID;

import java.util.ArrayList;

public class ConstraintDescriptorList extends ArrayList
{

  private boolean scanned;

  /**
   * Mark whether or not the underlying system table has
   * been scanned.  (If a table does not have any
   * constraints then the size of its CDL will always
   * be 0.  We used these get/set methods to determine
   * when we need to scan the table.
   *
   * @param scanned  Whether or not the underlying system table has been scanned.
   */
  public void setScanned(boolean scanned)
  {
    this.scanned = scanned;
  }

  /**
   * Return whether or not the underlying system table has been scanned.
   *
   * @return    Where or not the underlying system table has been scanned.
   */
  public boolean getScanned()
  {
    return scanned;
  }

  /**
   * Get the ConstraintDescriptor with the matching UUID String for the backing index.
   *
   * @param indexUUID    The UUID  for the backing index.
   *
   * @return The matching ConstraintDescriptor.
   */
  public ConstraintDescriptor getConstraintDescriptor(UUID indexUUID)
  {
    ConstraintDescriptor retCD = null;
    int size = size();

    for (int index = 0; index < size; index++)
    {
      ConstraintDescriptor cd = elementAt(index);

      if (! (cd instanceof KeyConstraintDescriptor))
      {
        continue;
      }

      KeyConstraintDescriptor keyCD = (KeyConstraintDescriptor) cd;

      if (keyCD.getIndexId().equals(indexUUID))
      {
        retCD = cd;
        break;
      }
    }
    return retCD;
  }

  /**
   * Get the ConstraintDescriptor with the matching constraint id.
   *
   * @param uuid    The constraint id.
   *
   * @return The matching ConstraintDescriptor.
   */
  public ConstraintDescriptor getConstraintDescriptorById(UUID uuid)
  {
    ConstraintDescriptor returnCD = null;
    int size = size();

    for (int index = 0; index < size; index++)
    {
      ConstraintDescriptor cd = elementAt(index);

      if (cd.getUUID().equals(uuid))
      {
        returnCD = cd;
        break;
      }
    }
    return returnCD;
  }

  /**
    *  Drop the constraint with the given UUID.
    *
    * @param uuid    The constraint id.
    *
    * @return The matching ConstraintDescriptor.
    */
  public ConstraintDescriptor dropConstraintDescriptorById(UUID uuid)
  {
    ConstraintDescriptor cd = null;
    int size = size();

    for (int index = 0; index < size; index++)
    {
      cd = elementAt(index);

      if (cd.getUUID().equals(uuid))
      {
        remove( cd );
        break;
      }
    }

    return cd;
  }



  /**
   * Get the ConstraintDescriptor with the matching constraint name.
   *
   * @param sd    The constraint schema descriptor.
   * @param name    The constraint name.
   *
   * @return The matching ConstraintDescriptor.
   */
  public ConstraintDescriptor getConstraintDescriptorByName(SchemaDescriptor sd,
                                String name)
  {
    ConstraintDescriptor retCD = null;
    int size = size();

    for (int index = 0; index < size; index++)
    {
      ConstraintDescriptor cd = elementAt(index);

      if (cd.getConstraintName().equals(name))
      {
        if ((sd == null) ||
          (sd.equals(cd.getSchemaDescriptor())))
        {
          retCD = cd;
          break;
        }
      }
    }
    return retCD;
  }


  /**
   * Get the ConstraintDescriptor with the matching constraint name.
   *
   * @return The matching ConstraintDescriptor.
   */
  public ReferencedKeyConstraintDescriptor getPrimaryKey()
  {
    int size = size();

    for (int index = 0; index < size; index++)
    {
      ConstraintDescriptor cd = elementAt(index);

      if (cd.getConstraintType() == DataDictionary.PRIMARYKEY_CONSTRAINT
      {
        return (ReferencedKeyConstraintDescriptor)cd;
      }
    }
    return (ReferencedKeyConstraintDescriptor)null;
  }

  /**
   * Return a list of constraints where enabled is
   * as passed in.
   *
   * @param enabled true or false
   *
   * @return a constraint descriptor list built from this.  Always
   * a new list even if all the elements in this were of the correct
   * type (i.e. not optimized for the case where every element is
   * desired).
   */
  public ConstraintDescriptorList getConstraintDescriptorList(boolean enabled)
  {
    ConstraintDescriptorList cdl = new ConstraintDescriptorList();
    int size = size();

    for (int index = 0; index < size; index++)
    {
      ConstraintDescriptor cd = elementAt(index);

      if (cd.isEnabled() == enabled)
      {
        cdl.add(cd);
      }
    }
    return cdl;
  }

  /**
   * Return the nth (0-based) element in the list.
   *
   * @param n  Which element to return.
   *
   * @return The nth element in the list.
   */
  public ConstraintDescriptor elementAt(int n)
  {
    return (ConstraintDescriptor) get(n);
  }

  /**
   * Return a ConstraintDescriptorList containing the ConstraintDescriptors
   * of the specified type that are in this list.
   *
   * @param type  The constraint type.
   *
   * @return A ConstraintDescriptorList containing the ConstraintDescriptors
   * of the specified type that are in this list.
   */
  public ConstraintDescriptorList getSubList(int type)
  {
    ConstraintDescriptor cd = null;
    ConstraintDescriptorList cdl = new ConstraintDescriptorList();
    int size = size();

    for (int index = 0; index < size; index++)
    {
      cd = elementAt(index);

      if (cd.getConstraintType() == type)
      {
        cdl.add(cd);
      }
    }
    return cdl;
  }
}
TOP

Related Classes of org.apache.derby.iapi.sql.dictionary.ConstraintDescriptorList

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.