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


Java OPERATION類代碼示例

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


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

示例1: manageToBooleanRangeCursor

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
protected ISchematicCursor manageToBooleanRangeCursor(ExecutionContext executionContext, ISchematicCursor cursor,
                                                      IRepository repo, IFilter keyFilter) throws TddlException {
    IBooleanFilter bf = (IBooleanFilter) keyFilter;
    IColumn c = ExecUtils.getColumn(bf.getColumn());
    OPERATION op = bf.getOperation();
    if (op == OPERATION.IN) {
        List<Object> values = bf.getValues();
        if (values == null) {
            throw new IllegalArgumentException("values is null ,but operation is in . logical error");
        } else {
            return repo.getCursorFactory().inCursor(executionContext, cursor, cursor.getOrderBy(), c, values, op);
        }
    }
    try {
        cursor = repo.getCursorFactory().rangeCursor(executionContext, cursor, keyFilter);
    } catch (Exception e) {
        throw new RuntimeException(e);
    }
    return cursor;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:21,代碼來源:QueryHandler.java

示例2: convertFilterToLowerAndTopLimit

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
protected void convertFilterToLowerAndTopLimit(RangeMaker.Range range, IFilter lf, ICursorMeta cursorMetaNew) {
    if (lf instanceof IBooleanFilter) {
        processBoolfilter(range, lf, cursorMetaNew);
    } else if (lf instanceof ILogicalFilter) {
        ILogicalFilter lo = (ILogicalFilter) lf;
        if (lo.getOperation() == OPERATION.OR) {
            throw new IllegalStateException("or ? should not be here");
        }
        List<IFilter> list = lo.getSubFilter();
        for (IFilter filter : list) {
            convertFilterToLowerAndTopLimit(range, filter, cursorMetaNew);
        }
    } else if (lf instanceof IGroupFilter) {
        throw new IllegalStateException("or ? should not be here");
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:17,代碼來源:RangeMaker.java

示例3: InCursor

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
public InCursor(Cursor cursor, List<IOrderBy> orderBys, IColumn c, List<Object> v, OPERATION op){
    super(cursor, null, orderBys);
    keyCodec = CodecFactory.getInstance(CodecFactory.FIXED_LENGTH)
        .getCodec(Arrays.asList(ExecUtils.getColumnMeta(c)));
    this.c = c;

    // if (c.getDataType() == DATA_TYPE.DATE_VAL) {
    // List<Object> vNew = new ArrayList<Object>(v.size());
    // for (Object comp : v) {
    // vNew.add(new Date((Long) comp));
    // }
    // v = vNew;
    // }
    this.valuesToFind = v;
    this.op = op;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:17,代碼來源:InCursor.java

示例4: toDNF

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
/**
 * 將一個Bool樹轉換成析取形式 A(B+C)轉換為AB+AC,不做拉平處理
 */
public static IFilter toDNF(IFilter node) {
    if (node == null) {
        return null;
    }

    while (!isDNF(node)) {
        if (node.getOperation().equals(OPERATION.OR)) {
            node = passOrNode((ILogicalFilter) node);
        } else if (node.getOperation().equals(OPERATION.AND)) {
            node = expandAndNode((ILogicalFilter) node);
        }
    }

    return node;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:19,代碼來源:FilterUtils.java

示例5: toDNFNodesArray

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
/**
 * 將一個IFilter全部展開為一個多維數組,會做拉平處理,需要預先調用toDNF/toDNFAndFlat進行預處理轉化為DNF範式
 * 
 * <pre>
 * 比如:(A and B) or (A and C)
 * 返回結果為: 
 *   List- 
 *      List 
 *         -(A , B)
 *      List
 *         -(A , C)
 * </pre>
 */
public static List<List<IFilter>> toDNFNodesArray(IFilter node) {
    if (node == null || !isDNF(node)) {
        return Lists.newLinkedList(); // 返回空的數組節點
    }

    List<List<IFilter>> res = new LinkedList();
    if (node.getOperation().equals(OPERATION.OR)) {
        for (int i = 0; i < ((ILogicalFilter) node).getSubFilter().size(); i++) {
            res.addAll(toDNFNodesArray(((ILogicalFilter) node).getSubFilter().get(i)));
        }
    } else if (node.getOperation().equals(OPERATION.AND)) {
        res.add(toDNFNode(node));
    } else {
        List<IFilter> DNFNode = new ArrayList<IFilter>(1);
        DNFNode.add(node);
        res.add(DNFNode);
    }

    if (res == null || res.isEmpty() || res.get(0) == null || res.get(0).isEmpty() || res.get(0).get(0) == null) {
        return new LinkedList<List<IFilter>>();
    } else {
        return res;
    }

}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:39,代碼來源:FilterUtils.java

示例6: addResultFilter

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
public void addResultFilter(IBooleanFilter filter) {
    if (this.resultFilter == null) {
        this.resultFilter = filter;
        return;
    }

    if (this.resultFilter instanceof ILogicalFilter) {
        // 添加為子節點
        ((ILogicalFilter) resultFilter).addSubFilter(filter);
        setNeedBuild(true);
    } else {
        // 將自己做為一個Logical filter的子條件
        IFilter sub = this.resultFilter;
        resultFilter = ASTNodeFactory.getInstance().createLogicalFilter();
        resultFilter.setOperation(OPERATION.AND);
        ((ILogicalFilter) resultFilter).addSubFilter(sub);
    }
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:19,代碼來源:QueryTreeNode.java

示例7: or

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
/**
 * 創建or條件
 */
public static IFilter or(IFilter root, IFilter o) {

    // 相等的情況下就不合並了
    if (root == o) {
        return root;
    }
    if (o == null) {
        return root;
    }

    if (root == null) {
        root = o;
    } else {
        if (root.getOperation().equals(OPERATION.OR)) {
            ((ILogicalFilter) root).addSubFilter(o);
        } else {
            ILogicalFilter and = ASTNodeFactory.getInstance().createLogicalFilter().setOperation(OPERATION.OR);
            and.addSubFilter(root);
            and.addSubFilter(o);
            root = and;
        }
    }
    return root;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:28,代碼來源:FilterUtils.java

示例8: visit

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
@Override
public void visit(BetweenAndExpression node) {
    Expression first = node.getFirst();
    Expression second = node.getSecond();
    Expression third = node.getThird();

    MySqlExprVisitor v = new MySqlExprVisitor(parent);
    first.accept(v);
    Object col = v.getColumnOrValue();

    MySqlExprVisitor lv = new MySqlExprVisitor(parent);
    second.accept(lv);
    Object lval = lv.getColumnOrValue();

    MySqlExprVisitor rv = new MySqlExprVisitor(parent);
    third.accept(rv);
    Object rval = rv.getColumnOrValue();

    IBooleanFilter left = this.buildBooleanFilter(col, lval, OPERATION.GT_EQ, node);
    IBooleanFilter right = this.buildBooleanFilter(col, rval, OPERATION.LT_EQ, node);
    ILogicalFilter ilf = buildLogicalFilter(left, right, OPERATION.AND, node);
    if (node.isNot()) {
        ilf.setIsNot(true);
    }
    this.filter = ilf;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:27,代碼來源:MySqlExprVisitor.java

示例9: addJoinOnColumns

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
private void addJoinOnColumns(IFilter ifilter, JoinNode joinNode) {
    if (ifilter instanceof IBooleanFilter) {
        joinNode.addJoinFilter((IBooleanFilter) ifilter);

    } else if (ifilter instanceof ILogicalFilter) {
        ILogicalFilter ilf = (ILogicalFilter) ifilter;
        if (!ilf.getOperation().equals(OPERATION.AND)) {
            // 比如出現 A.id = B.id And ( A.id = 1 or A.name = 3)
            // 這裏的or條件可直接做為other join filter
            // 如果出現 A.id = B.id OR A.name = B.name,那就是一個未知情況了
            joinNode.setOtherJoinOnFilter(ilf);
        } else {
            List<IFilter> subFilter = ilf.getSubFilter();
            if (subFilter != null) {
                for (IFilter one : subFilter) {
                    addJoinOnColumns(one, joinNode);
                }
            } else {
                throw new IllegalStateException("and has no other columns , " + ifilter);
            }
        }
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:24,代碼來源:MySqlExprVisitor.java

示例10: findBooleanFilter

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
private static void findBooleanFilter(IBooleanFilter filter, Parameters parameters) {
    if (filter == null) {
        return;
    }

    findObject(filter.getColumn(), parameters);
    findObject(filter.getValue(), parameters);
    if (filter.getOperation() == OPERATION.IN) {
        List<Object> values = filter.getValues();
        if (values != null && !values.isEmpty()) {
            for (int i = 0; i < values.size(); i++) {
                findObject(values.get(i), parameters);
            }
        }
    }

}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:18,代碼來源:SequencePreProcessor.java

示例11: testFunction_noArgs

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
@Test
public void testFunction_noArgs() throws Exception {
    String sql = "SELECT * FROM TABLE1 T1 WHERE ID = NOW()";
    QueryTreeNode qn = query(sql);
    qn.build();
    TableNode table1 = new TableNode("TABLE1");

    IFunction f = ASTNodeFactory.getInstance().createFunction();
    f.setFunctionName("NOW");
    f.setColumnName("NOW()");

    IColumn c = ASTNodeFactory.getInstance().createColumn();
    c.setColumnName("ID");

    IFilter filter = ASTNodeFactory.getInstance().createBooleanFilter();
    filter.setOperation(OPERATION.EQ);
    ((IBooleanFilter) filter).setColumn(c);
    ((IBooleanFilter) filter).setValue(f);

    QueryTreeNode qnExpected = table1.alias("T1").query(filter);
    qnExpected.build();
    assertEquals(qn, qnExpected);
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:24,代碼來源:SqlParserTest.java

示例12: manageToBooleanRangeCursor

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
protected ISchematicCursor manageToBooleanRangeCursor(ISchematicCursor cursor, IRepository repo, IFilter keyFilter,
                                                      ExecutionContext executionContext) throws TddlException {
    IBooleanFilter bf = (IBooleanFilter) keyFilter;
    IColumn c = ExecUtils.getColumn(bf.getColumn());
    OPERATION op = bf.getOperation();
    if (op == OPERATION.IN) {
        List<Object> values = bf.getValues();
        if (values == null) {
            throw new IllegalArgumentException("values is null ,but operation is in . logical error");
        } else {
            return repo.getCursorFactory().inCursor(executionContext, cursor, cursor.getOrderBy(), c, values, op);
        }
    }
    try {
        cursor = repo.getCursorFactory().rangeCursor(executionContext, cursor, keyFilter);
    } catch (Exception e) {
        throw new RuntimeException(e);
    }
    return cursor;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:21,代碼來源:HbQueryHandler.java

示例13: isCNFNode

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
/**
 * 是否為一簡單合取式
 */
public static boolean isCNFNode(IFilter node) {
    if (node == null) {
        return false;
    }

    if (node.getOperation().equals(OPERATION.AND)) {
        for (IFilter f : ((ILogicalFilter) node).getSubFilter())
            if (!isCNFNode(f)) {
                return false;
            }

    } else if (node.getOperation().equals(OPERATION.OR)) {
        return false;
    }

    return true;
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:21,代碼來源:FilterUtils.java

示例14: or

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
/**
 * 創建or條件
 */
public static IFilter or(IFilter root, IFilter o) {
    if (o == null) {
        return root;
    }

    if (root == null) {
        root = o;
    } else {
        if (root.getOperation().equals(OPERATION.OR)) {
            ((ILogicalFilter) root).addSubFilter(o);
        } else {
            ILogicalFilter and = ASTNodeFactory.getInstance().createLogicalFilter().setOperation(OPERATION.OR);
            and.addSubFilter(root);
            and.addSubFilter(o);
            root = and;
        }
    }
    return root;
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:23,代碼來源:FilterUtils.java

示例15: visit

import com.taobao.tddl.optimizer.core.expression.IFilter.OPERATION; //導入依賴的package包/類
@Override
public void visit(BetweenAndExpression node) {
    Expression first = node.getFirst();
    Expression second = node.getSecond();
    Expression third = node.getThird();

    MySqlExprVisitor v = new MySqlExprVisitor();
    first.accept(v);
    Comparable col = v.getColumnOrValue();

    MySqlExprVisitor lv = new MySqlExprVisitor();
    second.accept(lv);
    Comparable lval = lv.getColumnOrValue();

    MySqlExprVisitor rv = new MySqlExprVisitor();
    third.accept(rv);
    Comparable rval = rv.getColumnOrValue();

    IBooleanFilter left = this.buildBooleanFilter(col, lval, OPERATION.GT_EQ, node);
    IBooleanFilter right = this.buildBooleanFilter(col, rval, OPERATION.LT_EQ, node);
    ILogicalFilter ilf = buildLogicalFilter(left, right, OPERATION.AND, node);
    if (node.isNot()) {
        ilf.setIsNot(true);
    }
    this.filter = ilf;
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:27,代碼來源:MySqlExprVisitor.java


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