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

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


        }
        // Remove table descriptors whose statistics are considered up-to-date.
        // Iterate backwards to remove elements, chances are high the stats are
        // mostly up-to-date (minor performance optimization to avoid copy).
        for (int i=statsToUpdate.size() -1; i >= 0; i--) {
            TableDescriptor td = (TableDescriptor)statsToUpdate.get(i);
            if (td.getAndClearIndexStatsIsUpToDate()) {
                statsToUpdate.remove(i);
            }
        }
        if (statsToUpdate.isEmpty()) {
            return EMPTY_TD_LIST;
View Full Code Here


        fkNames = new String[size];
        conglomNumbers = new long[size];
        isSelfReferencingFK = new boolean[size];
        raRules = new int[size];
        ForeignKeyConstraintDescriptor fkcd = null;
        TableDescriptor fktd;
        ColumnDescriptorList coldl;
        int[] refColumns;
        ColumnDescriptor cold;
        int[] colArray = remapReferencedColumns(cd, rowMap);
        for (int inner = 0; inner < size; inner++)
        {
          fkcd = (ForeignKeyConstraintDescriptor) fkcdl.elementAt(inner);
          fkSetupArrays(dd, fkcd,
                inner, uuids, conglomNumbers, fkNames,
                isSelfReferencingFK, raRules);
          if((raRules[inner] == StatementType.RA_CASCADE) ||
             (raRules[inner] ==StatementType.RA_SETNULL))
          {
            //find  the referencing  table Name
            fktd = fkcd.getTableDescriptor();
            refTableNames.add(fktd.getSchemaName() + "." + fktd.getName());
            refActions.add(new Integer(raRules[inner]));
            //find the referencing column name required for update null.
            refColumns = fkcd.getReferencedColumns();
            coldl = fktd.getColumnDescriptorList();
            ColumnDescriptorList releventColDes = new ColumnDescriptorList();
            for(int i = 0 ; i < refColumns.length; i++)
            {
              cold =(ColumnDescriptor)coldl.elementAt(refColumns[i]-1);
              releventColDes.add(cold);
            }
            refColDescriptors.add(releventColDes);
            refIndexConglomNum.add(new Long(conglomNumbers[inner]));
            fkColMap.add(colArray);
          }
        }
      }
      else
      {
        continue;
      }

      TableDescriptor  pktd = refcd.getTableDescriptor();
      UUID pkuuid = refcd.getIndexId();
      ConglomerateDescriptor pkIndexConglom = pktd.getConglomerateDescriptor(pkuuid);

      TableDescriptor refTd = cd.getTableDescriptor();
      fkVector.add(new FKInfo(
                  fkNames,              // foreign key names
                  refTd.getName(),        // table being modified
                  statementType,            // INSERT|UPDATE|DELETE
                  type,                // FOREIGN_KEY|REFERENCED_KEY
                  pkuuid,                // referenced backing index uuid
                  pkIndexConglom.getConglomerateNumber(), // referened backing index conglom
                  uuids,                // fk backing index uuids
View Full Code Here

        "Exactly one of vtiTableFuncName or tableDescriptor should " +
        "be null, but neither or both of them were null.");
    }

    TableName vtiName = (TableName)vtiTableFuncName;
    TableDescriptor td = (TableDescriptor)tableDescriptor;
    boolean isTableFunctionVTI = (vtiTableFuncName != null);
    if (isTableFunctionVTI)
    {
      // We have to create a generic TableDescriptor to
      // pass to the data dictionary.
      td = new TableDescriptor(getDataDictionary(),
          vtiName.getTableName(),
          getSchemaDescriptor(vtiName.getSchemaName()),
          TableDescriptor.VTI_TYPE,
          TableDescriptor.DEFAULT_LOCK_GRANULARITY);
    }

    /* Use the table descriptor to figure out what the corresponding
     * VTI class name is; we let the data dictionary do the mapping
     * for us.
     */
    this.javaClassName = getDataDictionary().getVTIClass(
      td, isTableFunctionVTI);

    this.isBuiltinVTI =
        ( getDataDictionary().getBuiltinVTIClass( td, isTableFunctionVTI) != null);

    /* If javaClassName is still null at this point then we
     * could not find the target class for the received table
     * (or table function) name.  So throw the appropriate
     * error.
     */
    if (this.javaClassName == null)
    {
      if (!isTableFunctionVTI)
      {
        /* Create a TableName object from the table descriptor
         * that we received.  This gives us the name to use
         * in the error message.
         */
        vtiName = makeTableName(td.getSchemaName(),
          td.getDescriptorName());
      }

      throw StandardException.newException(
        isTableFunctionVTI
          ? SQLState.LANG_NO_SUCH_METHOD_ALIAS
View Full Code Here

   */
  protected final TableDescriptor getTableDescriptor(String tableName,
          SchemaDescriptor schema)
            throws StandardException
  {
    TableDescriptor retval;

    //Following if means we are dealing with SESSION schema.
    if (isSessionSchema(schema))
    {
      //First we need to look in the list of temporary tables to see if this table is a temporary table.
      retval = getLanguageConnectionContext().getTableDescriptorForDeclaredGlobalTempTable(tableName);
      if (retval != null)
        return retval; //this is a temporary table
    }

    //Following if means we are dealing with SESSION schema and we are dealing with in-memory schema (ie there is no physical SESSION schema)
    //If following if is true, it means SESSION.table is not a declared table & it can't be physical SESSION.table
    //because there is no physical SESSION schema
    if (schema.getUUID() == null)
      return null;

    //it is not a temporary table, so go through the data dictionary to find the physical persistent table
    TableDescriptor td = getDataDictionary().getTableDescriptor(tableName, schema,
                this.getLanguageConnectionContext().getTransactionCompile());
    if (td == null || td.isSynonymDescriptor())
      return null;

    return td;
  }
View Full Code Here

  public ResultSetNode bindNonVTITables(DataDictionary dataDictionary,
               FromList fromListParam)
          throws StandardException
  {
    TableDescriptor tableDescriptor = bindTableDescriptor();

    if (tableDescriptor.getTableType() == TableDescriptor.VTI_TYPE) {
      ResultSetNode vtiNode = getNodeFactory().mapTableAsVTI(
          tableDescriptor,
          getCorrelationName(),
          resultColumns,
          getProperties(),
          getContextManager());
      return vtiNode.bindNonVTITables(dataDictionary, fromListParam);
   
   
    ResultColumnList  derivedRCL = resultColumns;
 
    // make sure there's a restriction list
    restrictionList = (PredicateList) getNodeFactory().getNode(
                      C_NodeTypes.PREDICATE_LIST,
                      getContextManager());
    baseTableRestrictionList = (PredicateList) getNodeFactory().getNode(
                      C_NodeTypes.PREDICATE_LIST,
                      getContextManager());


    CompilerContext compilerContext = getCompilerContext();

    /* Generate the ResultColumnList */
    resultColumns = genResultColList();
    templateColumns = resultColumns;

    /* Resolve the view, if this is a view */
    if (tableDescriptor.getTableType() == TableDescriptor.VIEW_TYPE)
    {
      FromSubquery                fsq;
      ResultSetNode        rsn;
      ViewDescriptor        vd;
      CreateViewNode        cvn;
      SchemaDescriptor      compSchema;

      /* Get the associated ViewDescriptor so that we can get
       * the view definition text.
       */
      vd = dataDictionary.getViewDescriptor(tableDescriptor);

      /*
      ** Set the default compilation schema to be whatever
      ** this schema this view was originally compiled against.
      ** That way we pick up the same tables no matter what
      ** schema we are running against.
      */
      compSchema = dataDictionary.getSchemaDescriptor(vd.getCompSchemaId(), null);

      compilerContext.pushCompilationSchema(compSchema);
 
      try
      {
   
        /* This represents a view - query is dependent on the ViewDescriptor */
        compilerContext.createDependency(vd);
 
        if (SanityManager.DEBUG)
        {
          SanityManager.ASSERT(vd != null,
            "vd not expected to be null for " + tableName);
        }

        cvn = (CreateViewNode)
                  parseStatement(vd.getViewText(), false);

        rsn = cvn.getParsedQueryExpression();

        /* If the view contains a '*' then we mark the views derived column list
         * so that the view will still work, and return the expected results,
         * if any of the tables referenced in the view have columns added to
         * them via ALTER TABLE.  The expected results means that the view
         * will always return the same # of columns.
         */
        if (rsn.getResultColumns().containsAllResultColumn())
        {
          resultColumns.setCountMismatchAllowed(true);
        }
        //Views execute with definer's privileges and if any one of
        //those privileges' are revoked from the definer, the view gets
        //dropped. So, a view can exist in Derby only if it's owner has
        //all the privileges needed to create one. In order to do a
        //select from a view, a user only needs select privilege on the
        //view and doesn't need any privilege for objects accessed by
        //the view. Hence, when collecting privilege requirement for a
        //sql accessing a view, we only need to look for select privilege
        //on the actual view and that is what the following code is
        //checking.
        for (int i = 0; i < resultColumns.size(); i++) {
          ResultColumn rc = (ResultColumn) resultColumns.elementAt(i);
          if (rc.isPrivilegeCollectionRequired())
            compilerContext.addRequiredColumnPriv( rc.getTableColumnDescriptor());
        }

        fsq = (FromSubquery) getNodeFactory().getNode(
          C_NodeTypes.FROM_SUBQUERY,
          rsn,
                    cvn.getOrderByList(),
                    cvn.getOffset(),
                    cvn.getFetchFirst(),
          (correlationName != null) ?
                        correlationName : getOrigTableName().getTableName(),
          resultColumns,
          tableProperties,
          getContextManager());
        // Transfer the nesting level to the new FromSubquery
        fsq.setLevel(level);
        //We are getting ready to bind the query underneath the view. Since
        //that query is going to run with definer's privileges, we do not
        //need to collect any privilege requirement for that query.
        //Following call is marking the query to run with definer
        //privileges. This marking will make sure that we do not collect
        //any privilege requirement for it.
        fsq.disablePrivilegeCollection();
        fsq.setOrigTableName(this.getOrigTableName());

        // since we reset the compilation schema when we return, we
        // need to save it for use when we bind expressions:
        fsq.setOrigCompilationSchema(compSchema);
        ResultSetNode fsqBound =
          fsq.bindNonVTITables(dataDictionary, fromListParam);

        /* Do error checking on derived column list and update "exposed"
         * column names if valid.
         */
        if (derivedRCL != null) {
          fsqBound.getResultColumns().propagateDCLInfo(
            derivedRCL,
            origTableName.getFullTableName());
        }

        return fsqBound;
      }
      finally
      {
        compilerContext.popCompilationSchema();
      }
    }
    else
    {
      /* This represents a table - query is dependent on the TableDescriptor */
      compilerContext.createDependency(tableDescriptor);

      /* Get the base conglomerate descriptor */
      baseConglomerateDescriptor =
        tableDescriptor.getConglomerateDescriptor(
          tableDescriptor.getHeapConglomerateId()
          );

      /* Build the 0-based array of base column names. */
      columnNames = resultColumns.getColumnNames();

View Full Code Here

        // the transaction until loop below finds one it needs to
        // process.
       
        for (int i=0; i<allDeclaredGlobalTempTables.size(); i++)
        {
            TableDescriptor td =
                ((TempTableInfo) (allDeclaredGlobalTempTables.
                                      get(i))).getTableDescriptor();
            if (td.isOnCommitDeleteRows() == false)
            {
                // do nothing for temp table with ON COMMIT PRESERVE ROWS
                continue;
            }
            else if (checkIfAnyActivationHasHoldCursor(td.getName()) ==
                        false)
            {
                // temp tables with ON COMMIT DELETE ROWS and
                // no open held cursors
                getDataDictionary().getDependencyManager().invalidateFor(
View Full Code Here

        // network server, consistently remove temp tables at XA commit
        // transaction boundary.
        for (int i=0; i < allDeclaredGlobalTempTables.size(); i++)
        {
            // remove all temp tables from this context.
            TableDescriptor td =
                ((TempTableInfo)
                 (allDeclaredGlobalTempTables.get(i))).getTableDescriptor();

            //remove the conglomerate created for this temp table
            tc.dropConglomerate(td.getHeapConglomerateId());

            //remove it from the list of temp tables
            allDeclaredGlobalTempTables.remove(i);
        }
View Full Code Here

            try
            {
                TempTableInfo tempTableInfo =
                    (TempTableInfo)allDeclaredGlobalTempTables.get(i);

                TableDescriptor td = tempTableInfo.getTableDescriptor();

                // the following 2 lines of code has been copied from
                // DropTableConstantAction. If there are any changes made there
                // in future, we should check if they need to be made here too.
                dm.invalidateFor(td, DependencyManager.DROP_TABLE, this);
                tran.dropConglomerate(td.getHeapConglomerateId());

            }
            catch (StandardException e)
            {
                if (topLevelStandardException == null)
View Full Code Here

                    // the table was declared but not dropped in the unit of
                    // work getting rolled back and hence we will remove it
                    // from valid list of temporary tables and drop the
                    // conglomerate associated with it

                    TableDescriptor td = tempTableInfo.getTableDescriptor();

                    //remove the conglomerate created for this temp table
                    tran.dropConglomerate(td.getHeapConglomerateId());

                    //remove it from the list of temp tables
                    allDeclaredGlobalTempTables.remove(i);

                }
                else if (tempTableInfo.getDroppedInSavepointLevel() >=
                            currentSavepointLevel)
                {
                    // the table was declared and dropped in the unit of work
                    // getting rolled back
                    allDeclaredGlobalTempTables.remove(i);
                }
            }
            else if (tempTableInfo.getDroppedInSavepointLevel() >=
                        currentSavepointLevel)
            {
                // this means the table was declared in an earlier savepoint
                // unit / transaction and then dropped in current UOW

                // restore the old definition of temp table because drop is
                // being rolledback
                TableDescriptor td = tempTableInfo.getTableDescriptor();
                td = cleanupTempTableOnCommitOrRollback(td, false);

                // In order to store the old conglomerate information for the
                // temp table, we need to replace the existing table descriptor
                // with the old table descriptor which has the old conglomerate
                // information
                tempTableInfo.setTableDescriptor(td);
                tempTableInfo.setDroppedInSavepointLevel(-1);

                // following will mark the table as not modified. This is
                // because the table data has been deleted as part of the
                // current rollback
                tempTableInfo.setModifiedInSavepointLevel(-1);
                allDeclaredGlobalTempTables.set(i, tempTableInfo);
               
            }
            else if (tempTableInfo.getModifiedInSavepointLevel() >=
                    currentSavepointLevel)
            {
                // this means the table was declared in an earlier savepoint
                // unit / transaction and modified in current UOW

                // following will mark the table as not modified. This is
                // because the table data will be deleted as part of the
                // current rollback
                tempTableInfo.setModifiedInSavepointLevel(-1);
                TableDescriptor td = tempTableInfo.getTableDescriptor();

                getDataDictionary().getDependencyManager().invalidateFor(
                        td, DependencyManager.DROP_TABLE, this);

                cleanupTempTableOnCommitOrRollback(td, true);
View Full Code Here

  protected void dropSystemCatalog(TransactionController tc,
               CatalogRowFactory crf)
    throws StandardException
  {
    SchemaDescriptor    sd = bootingDictionary.getSystemSchemaDescriptor();
    TableDescriptor      td = bootingDictionary.getTableDescriptor(
                      crf.getCatalogName(),
                      sd, tc);
    ConglomerateDescriptor[]  cds = td.getConglomerateDescriptors();
    for (int index = 0; index < cds.length; index++)
    {
      tc.dropConglomerate(cds[index].getConglomerateNumber());
    }
    dropSystemCatalogDescription(tc,td);
View Full Code Here

TOP

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

Copyright © 2018 www.massapicom. 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.