Examples of IndexRowGenerator


Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

   * @exception StandardException    Thrown on error
   */
  public boolean isCoveringIndex(ConglomerateDescriptor cd) throws StandardException
  {
    boolean coveringIndex = true;
    IndexRowGenerator  irg;
    int[]        baseCols;
    int          colPos;

    /* You can only be a covering index if you're an index */
    if ( ! cd.isIndex())
      return false;

    irg = cd.getIndexDescriptor();
    baseCols = irg.baseColumnPositions();

    /* First we check to see if this is a covering index */
    int rclSize = resultColumns.size();
    for (int index = 0; index < rclSize; index++)
    {
View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

                    ConglomerateDescriptor idxCD,
                    ConglomerateDescriptor heapCD,
                    boolean cloneRCs)
            throws StandardException
  {
    IndexRowGenerator  irg = idxCD.getIndexDescriptor();
    int[]        baseCols = irg.baseColumnPositions();
    ResultColumnList  newCols =
                (ResultColumnList) getNodeFactory().getNode(
                        C_NodeTypes.RESULT_COLUMN_LIST,
                        getContextManager());
View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    int            indexNumber
    )
    throws StandardException
  {
    long            indexConglomerateNumber = tabInfo.getIndexConglomerate( indexNumber );
    IndexRowGenerator      indexRowGenerator = tabInfo.getIndexRowGenerator( indexNumber );
    CatalogRowFactory      rowFactory = tabInfo.getCatalogRowFactory();
    ExecRow            heapRow = rowFactory.makeEmptyRow();
    ExecIndexRow        indexableRow = indexRowGenerator.getIndexRowTemplate();

    ScanController        heapScan =
      tc.openScan(
        heapConglomerateNumber,       // conglomerate to open
        false,                          // don't hold open across commit
        0,                              // for read
                TransactionController.MODE_TABLE,
                TransactionController.ISOLATION_REPEATABLE_READ,
        (FormatableBitSet) null,                 // all fields as objects
        null,                           // start position - first row
        ScanController.GE,              // startSearchOperation
        null,                           //scanQualifier,
        null,                           //stop position-through last row
        ScanController.GT);             // stopSearchOperation

    RowLocation          heapLocation =
            heapScan.newRowLocationTemplate();

    ConglomerateController    indexController =
      tc.openConglomerate(
        indexConglomerateNumber,
                false,
        TransactionController.OPENMODE_FORUPDATE,
        TransactionController.MODE_TABLE,
        TransactionController.ISOLATION_REPEATABLE_READ);

    while ( heapScan.fetchNext(heapRow.getRowArray()) )
        {
       heapScan.fetchLocation( heapLocation );

      indexRowGenerator.getIndexRow( heapRow, heapLocation, indexableRow, (FormatableBitSet) null );

      indexController.insert(indexableRow.getRowArray());
    }

    indexController.close();
View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    DataValueDescriptor    col;
    String          tabID =null;
    Long          conglomNumber = null;
    String          conglomName = null;
    Boolean          supportsIndex = null;
    IndexRowGenerator    indexRowGenerator = null;
    Boolean          supportsConstraint = null;
    String          conglomUUIDString = null;
    String          schemaID = null;
    ConglomerateDescriptor  conglomerate = (ConglomerateDescriptor)td;

    /* Insert info into sysconglomerates */

    if (td != null)
    {
      /* Sometimes the SchemaDescriptor is non-null and sometimes it
       * is null.  (We can't just rely on getting the schema id from
       * the ConglomerateDescriptor because it can be null when
       * we are creating a new conglomerate.
       */
      if (parent != null)
      {
        SchemaDescriptor sd = (SchemaDescriptor)parent;
        schemaID = sd.getUUID().toString()
      }
      else
      {
        schemaID = conglomerate.getSchemaID().toString()
      }
      tabID = conglomerate.getTableID().toString();
      conglomNumber = new Long( conglomerate.getConglomerateNumber() );
      conglomName = conglomerate.getConglomerateName();
      conglomUUIDString = conglomerate.getUUID().toString();

      supportsIndex = new Boolean( conglomerate.isIndex() );
      indexRowGenerator = conglomerate.getIndexDescriptor();
      supportsConstraint = new Boolean( conglomerate.isConstraint() );
    }

    /* RESOLVE - It would be nice to require less knowledge about sysconglomerates
     * and have this be more table driven.
     */

    /* Build the row to insert */
    row = getExecutionFactory().getValueRow(SYSCONGLOMERATES_COLUMN_COUNT);

    /* 1st column is SCHEMAID (UUID - char(36)) */
    row.setColumn(1, dvf.getCharDataValue(schemaID));

    /* 2nd column is TABLEID (UUID - char(36)) */
    row.setColumn(2, dvf.getCharDataValue(tabID));

    /* 3rd column is CONGLOMERATENUMBER (long) */
    row.setColumn(3, dvf.getDataValue(conglomNumber));

    /* 4th column is CONGLOMERATENAME (varchar(128))
    ** If null, use the tableid so we always
    ** have a unique column
    */
    row.setColumn(4, (conglomName == null) ?
        dvf.getVarcharDataValue(tabID):
        dvf.getVarcharDataValue(conglomName));

    /* 5th  column is ISINDEX (boolean) */
    row.setColumn(5, dvf.getDataValue(supportsIndex));

    /* 6th column is DESCRIPTOR
    *  (user type org.apache.derby.catalog.IndexDescriptor)
    */
    row.setColumn(6,
      dvf.getDataValue(
            (indexRowGenerator == null ?
              (IndexDescriptor) null :
              indexRowGenerator.getIndexDescriptor()
            )
          )
        );

    /* 7th column is ISCONSTRAINT (boolean) */
 
View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    DataDescriptorGenerator  ddg = dd.getDataDescriptorGenerator();
    long conglomerateNumber;
    String  name;
    boolean isConstraint;
    boolean isIndex;
    IndexRowGenerator  indexRowGenerator;
    DataValueDescriptor col;
    ConglomerateDescriptor conglomerateDesc;
    String    conglomUUIDString;
    UUID    conglomUUID;
    String    schemaUUIDString;
    UUID    schemaUUID;
    String    tableUUIDString;
    UUID    tableUUID;

    /* 1st column is SCHEMAID (UUID - char(36)) */
    col = row.getColumn(1);
    schemaUUIDString = col.getString();
    schemaUUID = getUUIDFactory().recreateUUID(schemaUUIDString);

    /* 2nd column is TABLEID (UUID - char(36)) */
    col = row.getColumn(2);
    tableUUIDString = col.getString();
    tableUUID = getUUIDFactory().recreateUUID(tableUUIDString);


    /* 3nd column is CONGLOMERATENUMBER (long) */
    col = row.getColumn(3);
    conglomerateNumber = col.getLong();

    /* 4rd column is CONGLOMERATENAME (varchar(128)) */
    col = row.getColumn(4);
    name = col.getString();

    /* 5th column is ISINDEX (boolean) */
    col = row.getColumn(5);
    isIndex = col.getBoolean();

    /* 6th column is DESCRIPTOR */
    col = row.getColumn(6);
    indexRowGenerator = new IndexRowGenerator(
      (IndexDescriptor) col.getObject());

    /* 7th column is ISCONSTRAINT (boolean) */
    col = row.getColumn(7);
    isConstraint = col.getBoolean();
View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    ExecIndexRow        indexableRow;
    int              numColumns;
    long            conglomId;
    RowLocation          rl;
    CatalogRowFactory      rf = ti.getCatalogRowFactory();
    IndexRowGenerator      irg;
    ConglomerateDescriptor  conglomerateDescriptor;

    initSystemIndexVariables(ddg, ti, indexNumber);

    irg = ti.getIndexRowGenerator(indexNumber);

    numColumns = ti.getIndexColumnCount(indexNumber);

    /* Is the index unique */
    isUnique = ti.isIndexUnique(indexNumber);

    // create an index row template
    indexableRow = irg.getIndexRowTemplate();

    baseRow = rf.makeEmptyRow();

    // Get a RowLocation template
    cc = tc.openConglomerate(
      heapConglomerateNumber, false, 0,
            TransactionController.MODE_RECORD,
      TransactionController.ISOLATION_REPEATABLE_READ);

    rl = cc.newRowLocationTemplate();
    cc.close();

    // Get an index row based on the base row
    irg.getIndexRow(baseRow, rl, indexableRow, (FormatableBitSet) null);

    // Describe the properties of the index to the store using Properties
    // RESOLVE: The following properties assume a BTREE index.
    Properties  indexProperties = ti.getCreateIndexProperties(indexNumber);

View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    for (int i = 0; i < baseColumnPositions.length; i++)
      isAscending[i] = true;

    // For now, assume that all index columns are ordered columns
    ti.setIndexRowGenerator(indexNumber,
                new IndexRowGenerator(
                      "BTREE", ti.isIndexUnique(indexNumber),
                      baseColumnPositions,
                      isAscending,
                      baseColumnPositions.length));
  }
View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    boolean            forCreateTable;
    TableDescriptor       td;
    UUID             toid;
    ColumnDescriptor      columnDescriptor;
    int[]            baseColumnPositions;
    IndexRowGenerator      indexRowGenerator = null;
    ExecRow[]          baseRows;
    ExecIndexRow[]        indexRows;
    ExecRow[]          compactBaseRows;
    GroupFetchScanController    scan;
    RowLocationRetRowSource      rowSource;
    long            sortId;
    int              maxBaseColumnPosition = -1;

    LanguageConnectionContext lcc = activation.getLanguageConnectionContext();
    DataDictionary dd = lcc.getDataDictionary();
    DependencyManager dm = dd.getDependencyManager();
    TransactionController tc = lcc.getTransactionExecute();

    /* Remember whether or not we are doing a create table */
    forCreateTable = activation.getForCreateTable();

    /*
    ** Inform the data dictionary that we are about to write to it.
    ** There are several calls to data dictionary "get" methods here
    ** that might be done in "read" mode in the data dictionary, but
    ** it seemed safer to do this whole operation in "write" mode.
    **
    ** We tell the data dictionary we're done writing at the end of
    ** the transaction.
    */
    dd.startWriting(lcc);

    /*
    ** If the schema descriptor is null, then
    ** we must have just read ourselves in. 
    ** So we will get the corresponding schema
    ** descriptor from the data dictionary.
    */
    SchemaDescriptor sd = dd.getSchemaDescriptor(schemaName, tc, true) ;


    /* Get the table descriptor. */
    /* See if we can get the TableDescriptor
     * from the Activation.  (Will be there
     * for backing indexes.)
     */
    td = activation.getDDLTableDescriptor();

    if (td == null)
    {
      /* tableId will be non-null if adding an index to
       * an existing table (as opposed to creating a
       * table with a constraint with a backing index).
       */
      if (tableId != null)
      {
        td = dd.getTableDescriptor(tableId);
      }
      else
      {
        td = dd.getTableDescriptor(tableName, sd);
      }
    }

    if (td == null)
    {
      throw StandardException.newException(SQLState.LANG_CREATE_INDEX_NO_TABLE,
            indexName, tableName);
    }

    if (td.getTableType() == TableDescriptor.SYSTEM_TABLE_TYPE)
    {
      throw StandardException.newException(SQLState.LANG_CREATE_SYSTEM_INDEX_ATTEMPTED,
            indexName, tableName);
    }

    /* Get a shared table lock on the table. We need to lock table before
     * invalidate dependents, otherwise, we may interfere with the
     * compilation/re-compilation of DML/DDL.  See beetle 4325 and $WS/
     * docs/language/SolutionsToConcurrencyIssues.txt (point f).
     */
    lockTableForDDL(tc, td.getHeapConglomerateId(), false);

    // invalidate any prepared statements that
    // depended on this table (including this one)
    if (! forCreateTable)
    {
      dm.invalidateFor(td, DependencyManager.CREATE_INDEX, lcc);
    }

    // Translate the base column names to column positions
    baseColumnPositions = new int[columnNames.length];
    for (int i = 0; i < columnNames.length; i++)
    {
      // Look up the column in the data dictionary
      columnDescriptor = td.getColumnDescriptor(columnNames[i]);
      if (columnDescriptor == null)
      {
        throw StandardException.newException(SQLState.LANG_COLUMN_NOT_FOUND_IN_TABLE,
                              columnNames[i],
                              tableName);
      }

      TypeId typeId = columnDescriptor.getType().getTypeId();

      // Don't allow a column to be created on a non-orderable type
      ClassFactory cf = lcc.getLanguageConnectionFactory().getClassFactory();
      boolean isIndexable = typeId.orderable(cf);

      if (isIndexable && typeId.userType()) {
        String userClass = typeId.getCorrespondingJavaTypeName();

        // Don't allow indexes to be created on classes that
        // are loaded from the database. This is because recovery
        // won't be able to see the class and it will need it to
        // run the compare method.
        try {
          if (cf.isApplicationClass(cf.loadApplicationClass(userClass)))
            isIndexable = false;
        } catch (ClassNotFoundException cnfe) {
          // shouldn't happen as we just check the class is orderable
          isIndexable = false;
        }
      }

      if (!isIndexable) {
        throw StandardException.newException(SQLState.LANG_COLUMN_NOT_ORDERABLE_DURING_EXECUTION,
          typeId.getSQLTypeName());
      }

      // Remember the position in the base table of each column
      baseColumnPositions[i] = columnDescriptor.getPosition();

      if (maxBaseColumnPosition < baseColumnPositions[i])
        maxBaseColumnPosition = baseColumnPositions[i];
    }

    // check if we have similar indices already for this table
    ConglomerateDescriptor[] congDescs = td.getConglomerateDescriptors();
    boolean duplicate = false;

    for (int i = 0; i < congDescs.length; i++)
    {
      ConglomerateDescriptor cd = congDescs[i];
      if ( ! cd.isIndex())
        continue;
      IndexRowGenerator irg = cd.getIndexDescriptor();
      int[] bcps = irg.baseColumnPositions();
      boolean[] ia = irg.isAscending();
      int j = 0;

      /* For an index to be considered a duplicate of already existing index, the
       * following conditions have to be satisfied:
       * 1. the set of columns (both key and include columns) and their
       *  order in the index is the same as that of an existing index AND
       * 2. the ordering attributes are the same AND
       * 3. both the previously existing index and the one being created
       *  are non-unique OR the previously existing index is unique
       */

      if ((bcps.length == baseColumnPositions.length) &&
          (irg.isUnique() || !unique) &&
        indexType.equals(irg.indexType()))
      {
        for (; j < bcps.length; j++)
        {
          if ((bcps[j] != baseColumnPositions[j]) || (ia[j] != isAscending[j]))
            break;
        }
      }

      if (j == baseColumnPositions.length// duplicate
      {
        /*
         * Don't allow users to create a duplicate index. Allow if being done internally
         * for a constraint
         */
        if (!isConstraint)
        {
          activation.addWarning(
              StandardException.newWarning(
                SQLState.LANG_INDEX_DUPLICATE,
                cd.getConglomerateName()));

          return;
        }

        //Duplicate indexes share the physical conglomerate underneath
        conglomId = cd.getConglomerateNumber();
        indexRowGenerator = cd.getIndexDescriptor();
        //DERBY-655 and DERBY-1343 
        //Duplicate indexes will have unqiue logical conglomerate UUIDs. 
        conglomerateUUID = dd.getUUIDFactory().createUUID();
        duplicate = true;
        break;
      }
    }

    /* If this index already has an essentially same one, we share the
     * conglomerate with the old one, and just simply add a descriptor
     * entry into SYSCONGLOMERATES.
     */
    DataDescriptorGenerator ddg = dd.getDataDescriptorGenerator();
    if (duplicate)
    {
      ConglomerateDescriptor cgd =
        ddg.newConglomerateDescriptor(conglomId, indexName, true,
                      indexRowGenerator, isConstraint,
                      conglomerateUUID, td.getUUID(), sd.getUUID() );
      dd.addDescriptor(cgd, sd, DataDictionary.SYSCONGLOMERATES_CATALOG_NUM, false, tc);
      // add newly added conglomerate to the list of conglomerate
      // descriptors in the td.
      ConglomerateDescriptorList cdl =
        td.getConglomerateDescriptorList();
      cdl.add(cgd);

      // can't just return yet, need to get member "indexTemplateRow"
      // because create constraint may use it
    }

    // Describe the properties of the index to the store using Properties
    // RESOLVE: The following properties assume a BTREE index.
    Properties  indexProperties;
   
    if (properties != null)
    {
      indexProperties = properties;
    }
    else
    {
      indexProperties = new Properties();
    }

    // Tell it the conglomerate id of the base table
    indexProperties.put("baseConglomerateId",
              Long.toString(td.getHeapConglomerateId()));

    // All indexes are unique because they contain the RowLocation.
    // The number of uniqueness columns must include the RowLocation
    // if the user did not specify a unique index.
    indexProperties.put("nUniqueColumns",
          Integer.toString(unique ? baseColumnPositions.length :
                        baseColumnPositions.length + 1)
              );

    // By convention, the row location column is the last column
    indexProperties.put("rowLocationColumn",
              Integer.toString(baseColumnPositions.length));

    // For now, all columns are key fields, including the RowLocation
    indexProperties.put("nKeyFields",
              Integer.toString(baseColumnPositions.length + 1));

    // For now, assume that all index columns are ordered columns
    if (! duplicate)
    {
      indexRowGenerator = new IndexRowGenerator(indexType, unique,
                          baseColumnPositions,
                          isAscending,
                          baseColumnPositions.length);
    }

View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    throws StandardException
  {
    /*
    ** Construct a template row
    */
    IndexRowGenerator irg = fk.getIndexConglomerateDescriptor(dd).getIndexDescriptor()
    ExecIndexRow indexTemplateRow = irg.getIndexRowTemplate();
    TableDescriptor td = fk.getTableDescriptor();
    ExecRow baseRow = td.getEmptyExecRow(cm);
    irg.getIndexRow(baseRow, getRowLocation(dd, td, tc),
                indexTemplateRow, (FormatableBitSet)null);

    /*
    ** The moment of truth
    */
 
View Full Code Here

Examples of org.apache.derby.iapi.sql.dictionary.IndexRowGenerator

    DataValueDescriptor    col;
    String          tabID =null;
    Long          conglomNumber = null;
    String          conglomName = null;
    Boolean          supportsIndex = null;
    IndexRowGenerator    indexRowGenerator = null;
    Boolean          supportsConstraint = null;
    String          conglomUUIDString = null;
    String          schemaID = null;
    ConglomerateDescriptor  conglomerate = (ConglomerateDescriptor)td;

    /* Insert info into sysconglomerates */

    if (td != null)
    {
      /* Sometimes the SchemaDescriptor is non-null and sometimes it
       * is null.  (We can't just rely on getting the schema id from
       * the ConglomerateDescriptor because it can be null when
       * we are creating a new conglomerate.
       */
      if (parent != null)
      {
        SchemaDescriptor sd = (SchemaDescriptor)parent;
        schemaID = sd.getUUID().toString()
      }
      else
      {
        schemaID = conglomerate.getSchemaID().toString()
      }
      tabID = conglomerate.getTableID().toString();
      conglomNumber = new Long( conglomerate.getConglomerateNumber() );
      conglomName = conglomerate.getConglomerateName();
      conglomUUIDString = conglomerate.getUUID().toString();

      supportsIndex = new Boolean( conglomerate.isIndex() );
      indexRowGenerator = conglomerate.getIndexDescriptor();
      supportsConstraint = new Boolean( conglomerate.isConstraint() );
    }

    /* RESOLVE - It would be nice to require less knowledge about sysconglomerates
     * and have this be more table driven.
     */

    /* Build the row to insert */
    row = getExecutionFactory().getValueRow(SYSCONGLOMERATES_COLUMN_COUNT);

    /* 1st column is SCHEMAID (UUID - char(36)) */
    row.setColumn(1, new SQLChar(schemaID));

    /* 2nd column is TABLEID (UUID - char(36)) */
    row.setColumn(2, new SQLChar(tabID));

    /* 3rd column is CONGLOMERATENUMBER (long) */
    row.setColumn(3, dvf.getDataValue(conglomNumber));

    /* 4th column is CONGLOMERATENAME (varchar(128))
    ** If null, use the tableid so we always
    ** have a unique column
    */
    row.setColumn(4, (conglomName == null) ?
                new SQLVarchar(tabID): new SQLVarchar(conglomName));

    /* 5th  column is ISINDEX (boolean) */
    row.setColumn(5, dvf.getDataValue(supportsIndex));

    /* 6th column is DESCRIPTOR
    *  (user type org.apache.derby.catalog.IndexDescriptor)
    */
    row.setColumn(6,
      dvf.getDataValue(
            (indexRowGenerator == null ?
              (IndexDescriptor) null :
              indexRowGenerator.getIndexDescriptor()
            )
          )
        );

    /* 7th column is ISCONSTRAINT (boolean) */
 
View Full Code Here
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.