Package org.apache.derby.iapi.types

Examples of org.apache.derby.iapi.types.NumberDataValue


    if (incrementNeeded)
    {
      ExecRow readRow = ti.getRow(tc, keyRow,
                  SYSCOLUMNSRowFactory.SYSCOLUMNS_INDEX1_ID);
      NumberDataValue increment =
        (NumberDataValue)readRow.getColumn(SYSCOLUMNSRowFactory.SYSCOLUMNS_AUTOINCREMENTINC);
      aiValue += increment.getLong();
    }
    row.setColumn(SYSCOLUMNSRowFactory.SYSCOLUMNS_AUTOINCREMENTVALUE,
            dvf.getDataValue(aiValue));

    ti.updateRow(keyRow, row,
View Full Code Here


       */
      value = addend.cloneValue(false);
    }
    else
    {
      NumberDataValue  input = (NumberDataValue)addend;
      NumberDataValue nv = (NumberDataValue) value;

      value = nv.plus(
            input,            // addend 1
            nv,    // addend 2
            nv)// result
    }
  }
View Full Code Here

     
    case C_NodeTypes.DECIMAL_CONSTANT_NODE:
      if (valueInP)
      {

        NumberDataValue constantDecimal = getDataValueFactory().getDecimalDataValue((String) arg1);

        typeid = Types.DECIMAL;
        precision = constantDecimal.getDecimalValuePrecision();
        scal = constantDecimal.getDecimalValueScale();
        /* be consistent with our convention on maxwidth, see also
         * exactNumericType(), otherwise we get format problem, b 3923
         */
        maxwidth = DataTypeUtilities.computeMaxWidth(precision, scal);
        setValue(constantDecimal);
View Full Code Here

                // We're not prepared for a non-existing base row.
                SanityManager.ASSERT(baseRowExists, "base row not found");
            }

            // while the Row interface is 1 based.
            NumberDataValue currentAI = (NumberDataValue)row.getColumn(columnNum);
            long currentAIValue = currentAI.getLong();
           
            if (doUpdate)
            {
                // increment the value
                NumberDataValue increment = (NumberDataValue)row.getColumn(columnNum + 2);
                currentAI = currentAI.plus(currentAI, increment, currentAI);
                row.setColumn(columnNum, currentAI);

                // store the new value in SYSCOLUMNS
                FormatableBitSet columnToUpdate = new FormatableBitSet(
View Full Code Here

    if (incrementNeeded)
    {
      ExecRow readRow = ti.getRow(tc, keyRow,
                  SYSCOLUMNSRowFactory.SYSCOLUMNS_INDEX1_ID);
      NumberDataValue increment =
        (NumberDataValue)readRow.getColumn(SYSCOLUMNSRowFactory.SYSCOLUMNS_AUTOINCREMENTINC);
      aiValue += increment.getLong();
    }
    row.setColumn(SYSCOLUMNSRowFactory.SYSCOLUMNS_AUTOINCREMENTVALUE,
            new SQLLongint(aiValue));

    ti.updateRow(keyRow, row,
View Full Code Here

  public NumberDataValue
    getSetAutoincrementValue(int columnPosition, long increment)
    throws StandardException
  {
    long startValue = 0;
                NumberDataValue dvd;
    int index = columnPosition - 1// all our indices are 0 based.

    /* As in DB2, only for single row insert: insert into t1(c1) values (..) do
     * we return the correct most recently generated identity column value.  For
     * multiple row insert, or insert with sub-select, the return value is non-
     * deterministic, and is the previous return value of the IDENTITY_VAL_LOCAL
     * function, before the insert statement.  Also, DB2 can have at most 1 identity
     * column per table.  The return value won't be affected either if Derby
     * table has more than one identity columns.
     */
    setIdentity = (! autoincrementGenerated) && isSourceRowResultSet();
    autoincrementGenerated = true;

      if (bulkInsert)
      {
      ColumnDescriptor cd = td.getColumnDescriptor(columnPosition);
      long ret;

      // for bulk insert we have the table descriptor
      //      System.out.println("in bulk insert");
      if (aiCache[index].isNull())
      {
        if (bulkInsertReplace)
        {
          startValue = cd.getAutoincStart();
        }
        else
        {
          dvd = dd.getSetAutoincrementValue(
                constants.autoincRowLocation[index],
              tc, false, aiCache[index], true);
          startValue = dvd.getLong();
        }
        lcc.autoincrementCreateCounter(td.getSchemaName(),
                         td.getName(),
                         cd.getColumnName(),
                         new Long(startValue),
                         increment,
                         columnPosition);
     
      }     
      ret = lcc.nextAutoincrementValue(td.getSchemaName(),
                       td.getName(),
                       cd.getColumnName());
      aiCache[columnPosition - 1].setValue(ret);
   
    else
    {
      NumberDataValue newValue;
      TransactionController nestedTC = null, tcToUse = tc;

      try
      {
                // DERBY-5780, defaulting log syncing to false, which improves
                // performance of identity value generation.  If system
                // crashes may reuse an identity value because commit did not
                // sync, but only if no subsequent user transaction has
                // committed or aborted and thus no row can exist that used
                // the previous value.  Without this identity values pay
                // a synchronous I/O to the log file for each new value no
                // matter how many are inserted in a single transaction.
        nestedTC = tc.startNestedUserTransaction(false, false);
        tcToUse = nestedTC;
      }
      catch (StandardException se)
      {
        // If I cannot start a Nested User Transaction use the parent
        // transaction to do all the work.
        tcToUse = tc;
      }

      try
      {
        /* If tcToUse == tc, then we are using parent xaction-- this
           can happen if for some reason we couldn't start a nested
           transaction
        */
        newValue = dd.getSetAutoincrementValue(
               constants.autoincRowLocation[index],
               tcToUse, true, aiCache[index], (tcToUse == tc));
      }
      catch (StandardException se)
      {
        if (tcToUse == tc)
        {
          /* we've using the parent xaction and we've timed out; just
             throw an error and exit.
          */
          throw se;
        }

        if (se.getMessageId().equals(SQLState.LOCK_TIMEOUT))
        {
          // if we couldn't do this with a nested xaction, retry with
          // parent-- we need to wait this time!
          newValue = dd.getSetAutoincrementValue(
                  constants.autoincRowLocation[index],
                  tc, true, aiCache[index], true);
        }
        else if (se.getMessageId().equals(SQLState.LANG_OUTSIDE_RANGE_FOR_DATATYPE))
        {
          // if we got an overflow error, throw a more meaningful
          // error message
          throw StandardException.newException(
                         SQLState.LANG_AI_OVERFLOW,
                         se,
                         constants.getTableName(),
                         constants.getColumnName(index));
        }
        else throw se;
      }
      finally
      {
        // no matter what, commit the nested transaction; if something
        // bad happened in the child xaction lets not abort the parent
        // here.
               
        if (nestedTC != null)
        {
                    // DERBY-5493 - prior to fix all nested user update
                    // transactions did a nosync commit when commit() was
                    // called, this default has been changed to do synced
                    // commit.  Changed this commit to be commitNoSync to
                    // not introduce performce degredation for autoincrement
                    // keys.  As before, if server crashes the changes
                    // made in the nested transaction may be lost.  If any
                    // subsequent user transaction is commited, including any
                    // inserts that would depend on the autoincrement value
                    // change then the nested tranaction is guaranteed on
                    // system crash.
          nestedTC.commitNoSync(TransactionController.RELEASE_LOCKS);
          nestedTC.destroy();
        }
      }
      aiCache[index] = newValue;
      if (setIdentity)
        identityVal = newValue.getLong();
    }

    return aiCache[index];
   
  }
View Full Code Here

            if (SanityManager.DEBUG) {
                // We're not prepared for a non-existing base row.
                SanityManager.ASSERT(baseRowExists, "base row not found");
            }

      NumberDataValue oldValueOnDisk = (NumberDataValue) row.getColumn( columnNum );

            SQLLongint expectedOldValue;
            if ( oldValue == null ) { expectedOldValue = new SQLLongint(); }
            else { expectedOldValue = new SQLLongint( oldValue.longValue() ); }
View Full Code Here

    if (count == 0)
    {
      return null;
    }

    NumberDataValue sum = (NumberDataValue) value;
    NumberDataValue avg = (NumberDataValue) value.getNewNull();

   
    if (count > (long) Integer.MAX_VALUE)
    {
      // TINYINT, SMALLINT, INTEGER implement arithmetic using integers
      // If the sum is still represented as a TINYINT, SMALLINT or INTEGER
      // we cannot let their int based arithmetic handle it, since they
      // will perform a getInt() on the long value which will truncate the long value.
      // One solution would be to promote the sum to a SQLLongint, but its value
      // will be less than or equal to Integer.MAX_VALUE, so the average will be 0.
      String typeName = sum.getTypeName();

      if (typeName.equals(TypeId.INTEGER_NAME) ||
          typeName.equals(TypeId.TINYINT_NAME) ||
             typeName.equals(TypeId.SMALLINT_NAME))
      {
        avg.setValue(0);
        return avg;
      }
    }

    NumberDataValue countv = new org.apache.derby.iapi.types.SQLLongint(count);
    sum.divide(sum, countv, avg, scale);
       
    return avg;
  }
View Full Code Here

                return previous;
        }
        public final NumberDataValue getDecimalDataValue(Number value)
      throws StandardException
        {
      NumberDataValue ndv = getNullDecimal((NumberDataValue) null);
      ndv.setValue(value);
      return ndv;
        }
View Full Code Here

                heapCC.fetch(rl, row.getRowArray(), columnToRead, wait);

            columnToUpdate.set(columnNum - 1); // current value.

            // while the Row interface is 1 based.
            NumberDataValue currentAI = (NumberDataValue)row.getColumn(columnNum);
            long currentAIValue = currentAI.getLong();
           
            if (doUpdate)
            {
                // we increment and store the new value in SYSCOLUMNS
                NumberDataValue increment = (NumberDataValue)row.getColumn(columnNum + 2);
                currentAI = currentAI.plus(currentAI, increment, currentAI);
                row.setColumn(columnNum, currentAI);
                heapCC.replace(rl, row.getRowArray(), columnToUpdate);
            }
               
View Full Code Here

TOP

Related Classes of org.apache.derby.iapi.types.NumberDataValue

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.