All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.cassandra.cql.SelectExpression Maven / Gradle / Ivy

Go to download

The Apache Cassandra Project develops a highly scalable second-generation distributed database, bringing together Dynamo's fully distributed design and Bigtable's ColumnFamily-based data model.

There is a newer version: 2.1.07
Show newest version
/*
 * 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.cassandra.cql;

import java.util.ArrayList;
import java.util.List;

/**
 * Select expressions are analogous to the projection in a SQL query. They
 * determine which columns will appear in the result set.  SelectExpression
 * instances encapsulate a parsed expression from a SELECT
 * statement.
 *
 * See: doc/cql/CQL.html#SpecifyingColumns
 */
public class SelectExpression
{
    public static final int MAX_COLUMNS_DEFAULT = 10000;

    private int numColumns = MAX_COLUMNS_DEFAULT;
    private boolean reverseColumns = false;
    private final boolean hasFirstSet;
    private final boolean wildcard;
    private final Term start, finish;
    private final List columns;

    /**
     * Create a new SelectExpression for a range (slice) of columns.
     *
     * @param start the starting column name
     * @param finish the finishing column name
     * @param count the number of columns to limit the results to
     * @param reverse true to reverse column order
     * @param wildcard determines weather this statement is wildcard
     * @param firstSet determines weather "FIRST" keyword was set
     */
    public SelectExpression(Term start, Term finish, int count, boolean reverse, boolean wildcard, boolean firstSet)
    {
        this.start = start;
        this.finish = finish;
        numColumns = count;
        reverseColumns = reverse;
        this.wildcard = wildcard;
        hasFirstSet = firstSet;
        this.columns = null;
    }

    /**
     * Create a new SelectExpression for a list of columns.
     *
     * @param first the first (possibly only) column name to select on.
     * @param count the number of columns to limit the results on
     * @param reverse true to reverse column order
     * @param firstSet determines weather "FIRST" keyword was set
     */
    public SelectExpression(Term first, int count, boolean reverse, boolean firstSet)
    {
        wildcard = false;
        columns = new ArrayList();
        columns.add(first);
        numColumns = count;
        reverseColumns = reverse;
        hasFirstSet = firstSet;
        start = null;
        finish = null;
    }

    /**
     * Add an additional column name to a SelectExpression.
     *
     * @param addTerm
     */
    public void and(Term addTerm)
    {
        assert !isColumnRange();    // Not possible when invoked by parser
        columns.add(addTerm);
    }

    public boolean isColumnRange()
    {
        return (start != null);
    }

    public boolean isColumnList()
    {
        return !isColumnRange();
    }
    public int getColumnsLimit()
    {
        return numColumns;
    }

    public boolean isColumnsReversed()
    {
        return reverseColumns;
    }

    public void setColumnsReversed(boolean reversed)
    {
        reverseColumns = reversed;
    }

    public void setColumnsLimit(int limit)
    {
        numColumns = limit;
    }

    /**
     * @return weather expression includes "FIRST" keyword
     */
    public boolean hasFirstSet()
    {
        return hasFirstSet;
    }

    public Term getStart()
    {
        return start;
    }

    public Term getFinish()
    {
        return finish;
    }

    public List getColumns()
    {
        return columns;
    }

    public boolean isWildcard()
    {
        return wildcard;
    }

    public String toString()
    {
        return String.format("SelectExpression [numColumns=%s, reverseColumns=%s, hasFirstSet=%s, wildcard=%s, start=%s, finish=%s, columns=%s]",
                             numColumns,
                             reverseColumns,
                             hasFirstSet,
                             wildcard,
                             start,
                             finish,
                             columns);
    }


}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy