本文整理匯總了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;
}
示例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");
}
}
示例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;
}
示例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;
}
示例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;
}
}
示例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);
}
}
示例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;
}
示例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;
}
示例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);
}
}
}
}
示例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);
}
}
}
}
示例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);
}
示例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;
}
示例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;
}
示例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;
}
示例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;
}