當前位置: 首頁>>代碼示例>>Java>>正文


Java ExpressionType類代碼示例

本文整理匯總了Java中org.voltdb.types.ExpressionType的典型用法代碼示例。如果您正苦於以下問題:Java ExpressionType類的具體用法?Java ExpressionType怎麽用?Java ExpressionType使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ExpressionType類屬於org.voltdb.types包,在下文中一共展示了ExpressionType類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: isRangeQuery

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Returns true if the AbstractPlanNode contains a range query
 * @param rootNode
 * @return
 */
public static boolean isRangeQuery(AbstractPlanNode rootNode) {
    for (ExpressionType expType : getScanExpressionTypes(rootNode)) {
        switch (expType) {
            case COMPARE_GREATERTHAN:
            case COMPARE_GREATERTHANOREQUALTO:
            case COMPARE_IN:
            case COMPARE_LESSTHAN:
            case COMPARE_LESSTHANOREQUALTO:
            case COMPARE_LIKE:
            case CONJUNCTION_OR:
                return (true);
        } // SWITCH
    } // FOR
    return (false);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:21,代碼來源:PlanNodeUtil.java

示例2: compareWithConstant

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Handy method for creating a comparison expression between a tuple value
 * and a constant.
 *
 * @param <T>
 *            The type of the constant.
 * @param type
 *            The type of comparison.
 * @param left
 *            The name of the column of the left operand.
 * @param right
 *            The constant.
 * @return The expression representing the comparison operation.
 */
public static <T> Expression compareWithConstant(ExpressionType type,
                                                 String left,
                                                 T right) {
    switch (type) {
    case COMPARE_EQUAL:
        return new CompareEqual(value(left), constant(right));
    case COMPARE_NOTEQUAL:
        return new CompareNotEqual(value(left), constant(right));
    case COMPARE_GREATERTHAN:
        return new CompareGreaterThan(value(left), constant(right));
    case COMPARE_GREATERTHANOREQUALTO:
        return new CompareGreaterThanOrEqualTo(value(left), constant(right));
    case COMPARE_LESSTHAN:
        return new CompareLessThan(value(left), constant(right));
    case COMPARE_LESSTHANOREQUALTO:
        return new CompareLessThanOrEqualTo(value(left), constant(right));
    default:
        throw new IllegalArgumentException("Type must be a comparison type");
    }
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:35,代碼來源:Verification.java

示例3: compareTupleValues

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Handy method for creating a comparison expression between two tuple
 * values.
 *
 * @param type
 *            The type of comparison.
 * @param left
 *            The name of the column of the left operand.
 * @param right
 *            The name of the column of the right operand.
 * @return The expression representing the comparison operation.
 */
public static Expression compareTupleValues(ExpressionType type,
                                            String left,
                                            String right) {
    switch (type) {
    case COMPARE_EQUAL:
        return new CompareEqual(value(left), value(right));
    case COMPARE_NOTEQUAL:
        return new CompareNotEqual(value(left), value(right));
    case COMPARE_GREATERTHAN:
        return new CompareGreaterThan(value(left), value(right));
    case COMPARE_GREATERTHANOREQUALTO:
        return new CompareGreaterThanOrEqualTo(value(left), value(right));
    case COMPARE_LESSTHAN:
        return new CompareLessThan(value(left), value(right));
    case COMPARE_LESSTHANOREQUALTO:
        return new CompareLessThanOrEqualTo(value(left), value(right));
    default:
        throw new IllegalArgumentException("Type must be a comparison type");
    }
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:33,代碼來源:Verification.java

示例4: validate

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
@Override
public void validate() throws Exception {
    super.validate();
    //
    // We need to have an aggregate type and column
    // We're not checking that it's a valid ExpressionType because this plannode is a temporary hack
    //
    if (m_aggregateTypes.size() != m_aggregateColumnNames.size() ||
        m_aggregateColumnNames.size() != m_aggregateOutputColumns.size())
    {
        throw new Exception("ERROR: Mismatched number of aggregate expression column attributes for PlanNode '" + this + "'");
    } else if (m_aggregateTypes.isEmpty()|| m_aggregateTypes.contains(ExpressionType.INVALID)) {
        throw new Exception("ERROR: Invalid Aggregate ExpressionType or No Aggregate Expression types for PlanNode '" + this + "'");
    } else if (m_aggregateColumnNames.isEmpty()) {
        throw new Exception("ERROR: No Aggregate Columns for PlanNode '" + this + "'");
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:18,代碼來源:AggregatePlanNode.java

示例5: conjunction

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Handy method for creating a conjunction expression. Multiple expressions
 * can be given and they will all be joined with the same type.
 *
 * @param type
 *            The type of conjunction.
 * @param exps
 *            The expressions to conjunct.
 * @return The expression representing the conjunction.
 */
public static Expression conjunction(ExpressionType type, Expression... exps) {
    Expression prev = null;

    for (Expression exp : exps) {
        if (prev != null) {
            if (type == ExpressionType.CONJUNCTION_AND)
                prev = new ConjunctionAnd(prev, exp);
            else if (type == ExpressionType.CONJUNCTION_OR)
                prev = new ConjunctionOr(prev, exp);
            else
                throw new IllegalArgumentException("Type must be a conjunction type");
        } else {
            prev = exp;
        }
    }

    return prev;
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:29,代碼來源:Verification.java

示例6: loadFromJSONObject

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
@Override
protected void loadFromJSONObject(JSONObject obj, Database db) throws JSONException {
    JSONArray aggregateColumns = obj.getJSONArray(Members.AGGREGATE_COLUMNS.name());
    for (int ii = 0; ii < aggregateColumns.length(); ii++) {
        JSONObject aggregateColumn = aggregateColumns.getJSONObject(ii);
        m_aggregateTypes.add(ExpressionType.valueOf(aggregateColumn.getString(Members.AGGREGATE_TYPE.name())));
        m_aggregateColumnNames.add(aggregateColumn.getString(Members.AGGREGATE_NAME.name()));
        m_aggregateColumnGuids.add(aggregateColumn.getInt(Members.AGGREGATE_GUID.name()));
        m_aggregateOutputColumns.add(aggregateColumn.getInt(Members.AGGREGATE_OUTPUT_COLUMN.name()));
    }
    
    try {
        JSONArray groupbyColumnGuids = obj.getJSONArray(Members.GROUPBY_COLUMNS.name());
        for (int ii = 0; ii < groupbyColumnGuids.length(); ii++) {
            JSONObject jsonObject = groupbyColumnGuids.getJSONObject(ii);
            PlanColumn column = PlanColumn.fromJSONObject(jsonObject, db);
            m_groupByColumnGuids.add(column.guid());
        }
    } catch (JSONException e) {
        //okay not to be there.
    }
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:23,代碼來源:AggregatePlanNode.java

示例7: getScanExpressionTypes

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Return all the ExpressionTypes used for scan predicates in the given PlanNode
 * @param node
 * @return
 */
public static Collection<ExpressionType> getScanExpressionTypes(AbstractPlanNode root) {
    final Set<ExpressionType> found = new HashSet<ExpressionType>();
    new PlanNodeTreeWalker(true) {
        @Override
        protected void callback(AbstractPlanNode node) {
            Set<AbstractExpression> exps = new HashSet<AbstractExpression>();
            switch (node.getPlanNodeType()) {
                // SCANS
                case INDEXSCAN: {
                    IndexScanPlanNode idx_node = (IndexScanPlanNode) node;
                    exps.add(idx_node.getEndExpression());
                    exps.addAll(idx_node.getSearchKeyExpressions());
                }
                case SEQSCAN: {
                    AbstractScanPlanNode scan_node = (AbstractScanPlanNode) node;
                    exps.add(scan_node.getPredicate());
                    break;
                }
                // JOINS
                case NESTLOOP:
                case NESTLOOPINDEX: {
                    AbstractJoinPlanNode cast_node = (AbstractJoinPlanNode) node;
                    exps.add(cast_node.getPredicate());
                    break;
                }
                default:
                    // Do nothing...
            } // SWITCH

            for (AbstractExpression exp : exps) {
                if (exp == null)
                    continue;
                found.addAll(ExpressionUtil.getExpressionTypes(exp));
            } // FOR
            return;
        }
    }.traverse(root);
    return (found);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:45,代碼來源:PlanNodeUtil.java

示例8: factory

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
public static CatalogPair factory(CatalogType element0, CatalogType element1, ExpressionType comparison_exp, QueryType... query_types) {
    // Sort them!
    if (element0.compareTo(element1) > 0) {
        CatalogType temp = element0;
        element0 = element1;
        element1 = temp;
    }
    return (new CatalogPair(element0, element1, comparison_exp, query_types));
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:10,代碼來源:CatalogPair.java

示例9: isEqualityIndexScan

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Returns true if the given query is an equality predicate (with all the columns)
 * on a unique index. This essentially means that the query will only return
 * one row at runtime.
 * <B>WARNING:</B> This is wildly inaccurate and should not used by to make runtime decisions.
 * @param catalog_stmt
 * @return
 */
public static boolean isEqualityIndexScan(Statement catalog_stmt) {
    Collection<Table> tables = getReferencedTables(catalog_stmt);
    PredicatePairs cset = extractStatementPredicates(catalog_stmt, false, tables.toArray(new Table[0]));
    
    Collection<Index> indexes = getReferencedIndexes(catalog_stmt);
    
    for (CatalogPair cp : cset) {
        if (cp.getComparisonExp() != ExpressionType.COMPARE_EQUAL) {
            return (false);
        }
        
        CatalogType ctypes[] = { cp.getFirst(), cp.getSecond() };
        for (int i = 0; i < ctypes.length; i++) {
            if (ctypes[i] instanceof Column) {
                Column target_col = (Column)ctypes[i];
                Table target_tbl = target_col.getParent();

                // Find what index it's using
                // This is a rough approximation...
                Index target_idx = null;
                for (Index idx : indexes) {
                    if (idx.getParent().equals(target_tbl)) {
                        for (Column col : CatalogUtil.getColumns(idx.getColumns())) {
                            if (col.equals(target_col)) {
                                target_idx = idx;
                                break;
                            }
                        } // FOR
                    }
                } // FOR
                if (target_idx == null) {
                    return (false);
                }
            }
        } // FOR

    } // FOR
    return (true);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:48,代碼來源:CatalogUtil.java

示例10: createTempExpression

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Create a temporary column expression that can be used with
 * extractExpressionColumnSet
 * 
 * @param catalog_col
 * @param exp
 * @return
 */
private static AbstractExpression createTempExpression(Column catalog_col, AbstractExpression exp) {
    Table catalog_tbl = (Table) catalog_col.getParent();

    TupleValueExpression tuple_exp = new TupleValueExpression();
    tuple_exp.setTableName(catalog_tbl.getName());
    tuple_exp.setColumnIndex(catalog_col.getIndex());
    tuple_exp.setColumnAlias(catalog_col.getName());
    tuple_exp.setColumnName(catalog_col.getName());

    return (new ComparisonExpression(ExpressionType.COMPARE_EQUAL, tuple_exp, exp));
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:20,代碼來源:CatalogUtil.java

示例11: getExpressionTypes

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * Get all of the ExpressionTypes used in the tree below the given root
 * 
 * @param root
 * @return
 */
public static Collection<ExpressionType> getExpressionTypes(AbstractExpression root) {
    final Set<ExpressionType> found = new HashSet<ExpressionType>();
    new ExpressionTreeWalker() {
        @Override
        protected void callback(AbstractExpression element) {
            found.add(element.getExpressionType());
        }
    }.traverse(root);
    return (found);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:17,代碼來源:ExpressionUtil.java

示例12: add

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * @param element0
 * @param element1
 * @param comparison_exp
 * @param catalog_stmts
 * @return
 */
public boolean add(CatalogType element0, CatalogType element1, ExpressionType comparison_exp, Statement... catalog_stmts) {
    Set<Statement> stmts = new HashSet<Statement>();
    for (Statement stmt : catalog_stmts) {
        stmts.add(stmt);
    }
    return (this.add(element0, element1, comparison_exp, stmts));
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:15,代碼來源:PredicatePairs.java

示例13: put

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 * 
 * @param key
 * @param param
 * @param expType
 * @param catalog_tbl
 */
public void put(Column key, CatalogType param, ExpressionType expType, Table catalog_tbl) {
    assert(param instanceof StmtParameter || param instanceof ConstantValue);
    List<Pair<ExpressionType, CatalogType>> params = this.predicates.get(key);
    if (params == null) {
        params = new ArrayList<Pair<ExpressionType, CatalogType>>();
        this.predicates.put(key, params);
    }
    params.add(Pair.of(expType, param));
    this.table_keys.add(CatalogKey.createKey(catalog_tbl));
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:18,代碼來源:PartitionEstimator.java

示例14: buildConstraints

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
protected void buildConstraints() {
    Expression constraint = null;

    // PlayRound table 0: 0 <= C4 < 100 (max round is 100)
    constraint = Verification.inRange("C4", 0L, 99L);
    addConstraint("PlayRound", 0, constraint);

    // PlayRound table 1: 0 <= R_POT < 900 (because the max round is 100, we
    // only add at most 9 each time)
    Expression r_pot = Verification.inRange("R_POT", 0, 899);
    Expression t_id = Verification.compareWithConstant(ExpressionType.COMPARE_GREATERTHANOREQUALTO,
                                                       "T_ID", 0);
    Expression b_id = Verification.compareWithConstant(ExpressionType.COMPARE_GREATERTHANOREQUALTO,
                                                       "B_ID", 0);
    Expression r_id = Verification.compareWithConstant(ExpressionType.COMPARE_GREATERTHANOREQUALTO,
                                                       "R_ID", 0);
    constraint = Verification.conjunction(ExpressionType.CONJUNCTION_AND,
                                          r_pot, t_id, b_id, r_id);
    addConstraint("PlayRound", 1, constraint);

    // For the tables
    addConstraint("T", 0, t_id);

    constraint = Verification.conjunction(ExpressionType.CONJUNCTION_AND,
                                          t_id, b_id);
    addConstraint("B", 0, constraint);

    constraint = Verification.conjunction(ExpressionType.CONJUNCTION_AND,
                                          r_pot, t_id, r_id);
    addConstraint("R", 0, constraint);
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:32,代碼來源:BingoClient.java

示例15: getTablesForExpression

import org.voltdb.types.ExpressionType; //導入依賴的package包/類
/**
 *
 * @param db
 * @param expr
 * @param tables
 */
void getTablesForExpression(Database db, AbstractExpression expr, HashSet<Table> tables) {
    if (expr.getLeft() != null)
        getTablesForExpression(db, expr.getLeft(), tables);
    if (expr.getRight() != null)
        getTablesForExpression(db, expr.getRight(), tables);
    if (expr.getExpressionType() == ExpressionType.VALUE_TUPLE) {
        TupleValueExpression tupleExpr = (TupleValueExpression)expr;
        String tableName = tupleExpr.getTableName();
        Table table = db.getTables().getIgnoreCase(tableName);
        tables.add(table);
    }
}
 
開發者ID:s-store,項目名稱:s-store,代碼行數:19,代碼來源:AbstractParsedStmt.java


注:本文中的org.voltdb.types.ExpressionType類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。