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


Java ExpressionType.get方法代碼示例

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


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

示例1: parseOperationExpression

import org.voltdb.types.ExpressionType; //導入方法依賴的package包/類
/**
 *
 * @param exprNode
 * @param attrs
 * @param db
 * @return
 */
AbstractExpression parseOperationExpression(Node exprNode, NamedNodeMap attrs, Database db) {
    String type = attrs.getNamedItem("type").getNodeValue();
    ExpressionType exprType = ExpressionType.get(type);
    AbstractExpression expr = null;

    if (exprType == ExpressionType.INVALID) {
        throw new PlanningErrorException("Unsupported operation type '" + type + "'");
    }
    try {
        expr = exprType.getExpressionClass().newInstance();
    } catch (Exception e) {
        e.printStackTrace();
        System.exit(-1);
    }
    expr.setExpressionType(exprType);

    // Allow expressions to read expression-specific data from exprNode.
    // Looks like the design fully abstracts other volt classes from
    // the XML serialization?  Putting this here instead of in derived
    // Expression implementations.

    if (expr instanceof AggregateExpression) {
        Node node;
        if ((node = attrs.getNamedItem("distinct")) != null) {
            AggregateExpression ae = (AggregateExpression)expr;
            ae.m_distinct = Boolean.parseBoolean(node.getNodeValue());
        }
    }

    // setup for children access
    NodeList children = exprNode.getChildNodes();
    int i = 0;

    // get the first (left) node that is an element
    Node leftExprNode = children.item(i++);
    while ((leftExprNode != null) && (leftExprNode.getNodeType() != Node.ELEMENT_NODE))
        leftExprNode = children.item(i++);
    assert(leftExprNode != null);

    // get the second (right) node that is an element (might be null)
    Node rightExprNode = children.item(i++);
    while ((rightExprNode != null) && (rightExprNode.getNodeType() != Node.ELEMENT_NODE))
        rightExprNode = children.item(i++);

    // recursively parse the left subtree (could be another operator or
    // a constant/tuple/param value operand).
    AbstractExpression leftExpr = parseExpressionTree(leftExprNode, db);
    assert((leftExpr != null) || (exprType == ExpressionType.AGGREGATE_COUNT));
    expr.setLeft(leftExpr);

    if (ExpressionUtil.needsRightExpression(expr)) {
        assert(rightExprNode != null);

        // recursively parse the right subtree
        AbstractExpression rightExpr = parseExpressionTree(rightExprNode, db);
        assert(rightExpr != null);
        expr.setRight(rightExpr);
    }

    return expr;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:69,代碼來源:AbstractParsedStmt.java


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