Package org.apache.derby.iapi.types

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


  public BooleanDataValue in(DataValueDescriptor left,
                 DataValueDescriptor[] inList,
                 boolean orderedList)
            throws StandardException
  {
    BooleanDataValue retval = null;

    // in list should be non-empty
    if (SanityManager.DEBUG)
    {
      SanityManager.ASSERT(inList != null,
        "inList expected to be non-null");
      SanityManager.ASSERT(inList.length > 0,
        "inList.length expected to be > 0");
    }

    // if left is null then just return false
    if (left.isNull())
    {
      return SQLBoolean.truthValue(left,
                   inList[0],
                   false);
    }

    int start = 0;
    int finish = inList.length;

    /* Do a binary search if the list is ordered until the
     * range of values to search is 3 or less.
     *
     * NOTE: We may have sorted the IN-lst values at compile time using
     * a specific (dominant) type, but we did *not* actually cast the
     * values to that type.  So it's possible that different IN-list
     * values have different precedences (verses each other and also
     * verses the type of the left operand) when we get here.  Thus
     * when we do any comparisons here we have to make sure we always
     * compare using the dominant type of the two values being compared.
     * Otherwise we can end up with wrong results when doing the binary
     * search (ex. as caused by incorrect truncation).  DERBY-2256.
     */
    int leftPrecedence = left.typePrecedence();
    DataValueDescriptor comparator = null;
    if (orderedList)
    {
      while (finish - start > 2)
      {
        int mid = ((finish - start) / 2) + start;
        comparator =
          (leftPrecedence < inList[mid].typePrecedence())
            ? inList[mid]
            : left;

        // Search left
        retval = comparator.equals(left, inList[mid]);
        if (retval.equals(true))
        {
          return retval;
        }
        BooleanDataValue goLeft =
          comparator.greaterThan(inList[mid], left);
        if (goLeft.equals(true))
        {
          // search left
          finish = mid;
        }
        else
        {
          // search right
          start = mid;
        }
      }
    }

    /* Walk the in list comparing the values.  Return as soon as we
     * find a match.  If the list is ordered, return as soon as the left
     * value is greater than an element in the in list.
     *
     * Note: for the same reasons outlined above we must be sure to always
     * do the comparisons using the dominant type of the two values being
     * compared.
     */
    for (int index = start; index < finish; index++)
    {
      comparator =
        (leftPrecedence < inList[index].typePrecedence())
          ? inList[index]
          : left;

      retval = comparator.equals(left, inList[index]);
      if (retval.equals(true))
      {
        break;
      }

      // Can we stop searching?
      if (orderedList)
      {
        BooleanDataValue stop =
          comparator.greaterThan(inList[index], left);
        if (stop.equals(true))
        {
          break;
        }
      }
    }
View Full Code Here


        for (i = 0; i < colsToCheck.length; i++)
        {
          checkCol = (DataValueDescriptor)checkRowArray[colsToCheck[i]-1];
          scanCol = (DataValueDescriptor)scanRowArray[colsToCheck[i]-1];

          BooleanDataValue result = checkCol.equals(
                      scanCol,
                      checkCol); // result
          if (!result.getBoolean())
          {
            break;
          }
        }
        if (i == colsToCheck.length)
View Full Code Here

  public BooleanDataValue in(DataValueDescriptor left,
                 DataValueDescriptor[] inList,
                 boolean orderedList)
            throws StandardException
  {
    BooleanDataValue retval = null;

    // in list should be non-empty
    if (SanityManager.DEBUG)
    {
      SanityManager.ASSERT(inList != null,
        "inList expected to be non-null");
      SanityManager.ASSERT(inList.length > 0,
        "inList.length expected to be > 0");
    }

    // if left is null then just return false
    if (left.isNull())
    {
      return SQLBoolean.truthValue(left,
                   inList[0],
                   false);
    }

    int start = 0;
    int finish = inList.length;

    /* Do a binary search if the list is ordered until the
     * range of values to search is 3 or less.
     *
     * NOTE: We may have sorted the IN-lst values at compile time using
     * a specific (dominant) type, but we did *not* actually cast the
     * values to that type.  So it's possible that different IN-list
     * values have different precedences (verses each other and also
     * verses the type of the left operand) when we get here.  Thus
     * when we do any comparisons here we have to make sure we always
     * compare using the dominant type of the two values being compared.
     * Otherwise we can end up with wrong results when doing the binary
     * search (ex. as caused by incorrect truncation).  DERBY-2256.
     */
    int leftPrecedence = left.typePrecedence();
    DataValueDescriptor comparator = null;
    if (orderedList)
    {
      while (finish - start > 2)
      {
        int mid = ((finish - start) / 2) + start;
        comparator =
          (leftPrecedence < inList[mid].typePrecedence())
            ? inList[mid]
            : left;

        // Search left
        retval = comparator.equals(left, inList[mid]);
        if (retval.equals(true))
        {
          return retval;
        }
        BooleanDataValue goLeft =
          comparator.greaterThan(inList[mid], left);
        if (goLeft.equals(true))
        {
          // search left
          finish = mid;
        }
        else
        {
          // search right
          start = mid;
        }
      }
    }

    /* Walk the in list comparing the values.  Return as soon as we
     * find a match.  If the list is ordered, return as soon as the left
     * value is greater than an element in the in list.
     *
     * Note: for the same reasons outlined above we must be sure to always
     * do the comparisons using the dominant type of the two values being
     * compared.
     */
    for (int index = start; index < finish; index++)
    {
      comparator =
        (leftPrecedence < inList[index].typePrecedence())
          ? inList[index]
          : left;

      retval = comparator.equals(left, inList[index]);
      if (retval.equals(true))
      {
        break;
      }

      // Can we stop searching?
      if (orderedList)
      {
        BooleanDataValue stop =
          comparator.greaterThan(inList[index], left);
        if (stop.equals(true))
        {
          break;
        }
      }
    }
View Full Code Here

   * @return  NOT( this IS otherValue )
   *
   */
  public BooleanDataValue isNot(BooleanDataValue otherValue)
  {
    BooleanDataValue  isValue = is( otherValue );

    if ( isValue.equals(true) ) { return BOOLEAN_FALSE; }
    else { return BOOLEAN_TRUE; }
  }
View Full Code Here

        for (i = 0; i < colsToCheck.length; i++)
        {
          checkCol = (DataValueDescriptor)checkRowArray[colsToCheck[i]-1];
          scanCol = (DataValueDescriptor)scanRowArray[colsToCheck[i]-1];

          BooleanDataValue result = checkCol.equals(
                      scanCol,
                      checkCol); // result
          if (!result.getBoolean())
          {
            break;
          }
        }
        if (i == colsToCheck.length)
View Full Code Here

   * @return  NOT( this IS otherValue )
   *
   */
  public BooleanDataValue isNot(BooleanDataValue otherValue)
  {
    BooleanDataValue  isValue = is( otherValue );

    if ( isValue.equals(true) ) { return BOOLEAN_FALSE; }
    else { return BOOLEAN_TRUE; }
  }
View Full Code Here

        for (i = 0; i < colsToCheck.length; i++)
        {
          checkCol = (DataValueDescriptor)checkRowArray[colsToCheck[i]-1];
          scanCol = (DataValueDescriptor)scanRowArray[colsToCheck[i]-1];

          BooleanDataValue result = checkCol.equals(
                      scanCol,
                      checkCol); // result
          if (!result.getBoolean())
          {
            break;
          }
        }
        if (i == colsToCheck.length)
View Full Code Here

        for (i = 0; i < colsToCheck.length; i++)
        {
          checkCol = (DataValueDescriptor)checkRowArray[colsToCheck[i]-1];
          scanCol = (DataValueDescriptor)scanRowArray[colsToCheck[i]-1];

          BooleanDataValue result = checkCol.equals(
                      scanCol,
                      checkCol); // result
          if (!result.getBoolean())
          {
            break;
          }
        }
        if (i == colsToCheck.length)
View Full Code Here

   * @return  NOT( this IS otherValue )
   *
   */
  public BooleanDataValue isNot(BooleanDataValue otherValue)
  {
    BooleanDataValue  isValue = is( otherValue );

    if ( isValue.equals(true) ) { return BOOLEAN_FALSE; }
    else { return BOOLEAN_TRUE; }
  }
View Full Code Here

  public BooleanDataValue in(DataValueDescriptor left,
                 DataValueDescriptor[] inList,
                 boolean orderedList)
            throws StandardException
  {
    BooleanDataValue retval = null;

    // in list should be non-empty
    if (SanityManager.DEBUG)
    {
      SanityManager.ASSERT(inList != null,
        "inList expected to be non-null");
      SanityManager.ASSERT(inList.length > 0,
        "inList.length expected to be > 0");
    }

    // if left is null then just return false
    if (left.isNull())
    {
      return SQLBoolean.truthValue(left,
                   inList[0],
                   false);
    }

    int start = 0;
    int finish = inList.length;

    /* Do a binary search if the list is ordered until the
     * range of values to search is 3 or less.
     * NOTE: We've ensured that the IN list and the left all have
     * the same precedence at compile time.  If we don't enforce
     * the same precendence then
     * we could get the wrong result when doing a binary search.
     */
    if (orderedList)
    {
      while (finish - start > 2)
      {
        int mid = ((finish - start) / 2) + start;
        // Search left
        retval = equals(left, inList[mid]);
        if (retval.equals(true))
        {
          return retval;
        }
        BooleanDataValue goLeft = greaterThan(inList[mid], left);
        if (goLeft.equals(true))
        {
          // search left
          finish = mid;
        }
        else
        {
          // search right
          start = mid;
        }
      }
    }

    /* Walk the in list comparing the values.  Return as soon as we
     * find a match.  If the list is ordered, return as soon as the left
     * value is greater than an element in the in list.
     */
    for (int index = start; index < finish; index++)
    {
      retval = equals(left, inList[index]);
      if (retval.equals(true))
      {
        break;
      }

      // Can we stop searching?
      if (orderedList)
      {
        BooleanDataValue stop = greaterThan(inList[index], left);
        if (stop.equals(true))
        {
          break;
        }
      }
    }
View Full Code Here

TOP

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

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.