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


Java TableNode類代碼示例

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


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

示例1: visit

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Override
public void visit(DMLUpdateStatement node) {
    QueryTreeNode table = getTableNode(node);
    List<Pair<Identifier, Expression>> cvs = node.getValues();
    Object[] updateValues = new Object[cvs.size()];
    StringBuilder updateColumnsSb = new StringBuilder();
    for (int i = 0; i < cvs.size(); i++) {
        Pair<Identifier, Expression> p = cvs.get(i);
        if (i > 0) {
            updateColumnsSb.append(" ");
        }
        updateColumnsSb.append(p.getKey().getIdTextUpUnescape());
        MySqlExprVisitor mv = new MySqlExprVisitor();
        p.getValue().accept(mv);
        updateValues[i] = mv.getColumnOrValue();// 可能為function
    }

    Expression expr = node.getWhere();
    if (expr != null) {
        handleCondition(table, expr);
    }

    this.updateNode = ((TableNode) table).update(updateColumnsSb.toString(), updateValues);
    updateNode.setIgnore(node.isIgnore());
    updateNode.setLowPriority(node.isLowPriority());
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:27,代碼來源:MySqlUpdateVisitor.java

示例2: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
public void test_單表merge_函數下推() {
    TableNode table = new TableNode("TABLE1");
    table.select("MAX(ID) AS ID");
    table.orderBy("COUNT(ID)");
    table.groupBy("SUBSTRING(NAME,0,10)");
    table.having("COUNT(ID) > 1");
    IQueryTree qc = (IQueryTree) optimizer.optimizeAndAssignment(table, null, extraCmd);
    Assert.assertTrue(qc instanceof IMerge);
    Assert.assertEquals(QUERY_CONCURRENCY.CONCURRENT, ((IMerge) qc).getQueryConcurrency());// 並行

    IDataNodeExecutor dne = ((IMerge) qc).getSubNodes().get(0);
    Assert.assertTrue(dne instanceof IQuery);
    IQuery query = (IQuery) dne;
    Assert.assertEquals("SUBSTRING(NAME, 0, 10)", query.getColumns().get(1).toString());// 下推成功
    Assert.assertEquals("COUNT(ID)", query.getColumns().get(2).toString());// 下推成功
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:17,代碼來源:OptimizerTest.java

示例3: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void test_join條件下推_子表_case4_下推IDNAME() {
    TableNode table1 = new TableNode("TABLE1");
    TableNode table2 = new TableNode("TABLE2");
    table1.alias("A");
    table2.alias("B");

    JoinNode join = table1.join(table2);
    join.setJoinStrategy(JoinStrategy.INDEX_NEST_LOOP);
    join.orderBy("A.ID");
    join.orderBy("A.NAME");
    join.build();

    OrderByPusher.optimize(join);

    Assert.assertEquals(2, table1.getOrderBys().size());
    Assert.assertEquals("TABLE1.ID", table1.getOrderBys().get(0).getColumn().toString());
    Assert.assertEquals("TABLE1.NAME", table1.getOrderBys().get(1).getColumn().toString());
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:20,代碼來源:OrderByPusherTest.java

示例4: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
/**
 * C4,C5上隻存在倒排索引,單C4的選擇更高,選擇C4倒排
 */
@Test
public void testChooseIndex選擇倒排索引() throws QueryException {
    TableNode table = new TableNode("TABLE9");
    QueryTreeNode qn = table.query("C4=10&&C5>3");
    qn.build();

    IndexMeta index = IndexChooser.findBestIndex(table.getTableMeta(),
        table.getColumnsRefered(),
        toDNFFilter(table.getWhereFilter()),
        table.getTableName(),
        extraCmd);

    Assert.assertNotNull(index);
    Assert.assertEquals(index.getName(), "TABLE9._C4");
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:19,代碼來源:IndexChooserTest.java

示例5: testDistinct

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void testDistinct() throws SqlParserException, QueryException {
    String sql = "SELECT COUNT(DISTINCT ID) FROM TABLE1";
    QueryTreeNode qn = query(sql);

    TableNode table1 = new TableNode("TABLE1");
    IColumn c = ASTNodeFactory.getInstance().createColumn();
    c.setColumnName("ID");
    c.setDistinct(true);

    IFunction f = ASTNodeFactory.getInstance().createFunction();
    f.setFunctionName("COUNT");
    f.setColumnName("COUNT(DISTINCT ID)");

    List args = new ArrayList();
    args.add(c);
    f.setArgs(args);
    qn.build();

    QueryTreeNode qnExpected = table1.select(f);
    qnExpected.build();
    assertEquals(qn, qnExpected);
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:24,代碼來源:SqlParserTest.java

示例6: preProcess

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
private static QueryTreeNode preProcess(QueryTreeNode qtn, boolean typeConvert, Map<String, Object> extraCmd) {
    qtn.setOtherJoinOnFilter(processFilter(qtn.getOtherJoinOnFilter(), typeConvert, extraCmd));
    qtn.having(processFilter(qtn.getHavingFilter(), typeConvert, extraCmd));
    qtn.query(processFilter(qtn.getWhereFilter(), typeConvert, extraCmd));
    qtn.setKeyFilter(processFilter(qtn.getKeyFilter(), typeConvert, extraCmd));
    qtn.setResultFilter(processFilter(qtn.getResultFilter(), typeConvert, extraCmd));
    if (qtn instanceof TableNode) {
        ((TableNode) qtn).setIndexQueryValueFilter(processFilter(((TableNode) qtn).getIndexQueryValueFilter(),
            typeConvert,
            extraCmd));
    }

    if (qtn instanceof JoinNode) {
        for (int i = 0; i < ((JoinNode) qtn).getJoinFilter().size(); i++) {
            processFilter(((JoinNode) qtn).getJoinFilter().get(i), typeConvert, extraCmd);
        }
    }

    for (ASTNode child : qtn.getChildren()) {
        preProcess((QueryTreeNode) child, typeConvert, extraCmd);
    }

    return qtn;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:25,代碼來源:FilterPreProcessor.java

示例7: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void test_合並_OR條件() {
    TableNode table = new TableNode("TABLE1");
    table.query("ID > 1 OR ID < 3");
    table.build();
    FilterPreProcessor.optimize(table, true, null);
    Assert.assertEquals(table.getWhereFilter().toString(), "1");

    table.query("ID > 1 OR ID > 3");
    table.build();
    FilterPreProcessor.optimize(table, true, null);
    Assert.assertEquals(table.getWhereFilter().toString(), "TABLE1.ID > 1");

    table.query("ID > 1 OR ID = 5");
    table.build();
    FilterPreProcessor.optimize(table, true, null);
    Assert.assertEquals(table.getWhereFilter().toString(), "TABLE1.ID > 1");
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:19,代碼來源:FilterPreProcessorTest.java

示例8: testPreparedDeleteSql

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void testPreparedDeleteSql() throws SqlParserException, QueryException {
    String sql = "DELETE FROM TABLE1 WHERE ID>=? AND ID<=?";
    DeleteNode dn = delete(sql);

    Map<Integer, ParameterContext> parameterSettings = null;
    parameterSettings = new TreeMap<Integer, ParameterContext>();
    ParameterContext p1 = new ParameterContext(ParameterMethod.setObject1, new Object[] { 0, 3 });
    ParameterContext p2 = new ParameterContext(ParameterMethod.setObject1, new Object[] { 1, 5 });
    parameterSettings.put(1, p1);
    parameterSettings.put(2, p2);

    dn.assignment(parameterSettings);
    dn.build();

    TableNode table1 = new TableNode("TABLE1");
    DeleteNode dnExpected = table1.delete();
    table1.query("ID>=3 AND ID<=5");
    dnExpected.build();
    assertEquals(dn, dnExpected);
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:22,代碼來源:SqlParserTest.java

示例9: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void test_合並_AND條件() {
    TableNode table = new TableNode("TABLE1");
    table.query("ID > 1 AND ID < 10");
    table.build();
    FilterPreProcessor.optimize(table, true);
    Assert.assertEquals(table.getWhereFilter().toString(), "(TABLE1.ID > 1 AND TABLE1.ID < 10)");

    table.query("ID > 1 AND ID < 10 AND ID >= 2 AND ID < 11");
    table.build();
    FilterPreProcessor.optimize(table, true);
    Assert.assertEquals(table.getWhereFilter().toString(), "(TABLE1.ID >= 2 AND TABLE1.ID < 10)");

    table.query("ID > 1 AND ID < 0");
    table.build();
    try {
        FilterPreProcessor.optimize(table, true);
        Assert.fail();
    } catch (EmptyResultFilterException e) {
        // 會出現EmptyResultFilterException異常
    }
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:23,代碼來源:FilterPreProcessorTest.java

示例10: query

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void testQuery_左連接() throws SqlParserException {
    String sql = "SELECT * FROM TABLE1 A LEFT JOIN TABLE2 B ON A.ID=B.ID WHERE A.NAME=1";
    QueryTreeNode qn = query(sql);
    qn.build();

    TableNode table1 = new TableNode("TABLE1");
    TableNode table2 = new TableNode("TABLE2");
    QueryTreeNode qnExpected = table1.alias("A")
        .join(table2.alias("B"))
        .setLeftOuterJoin()
        .addJoinKeys("A.ID", "B.ID")
        .query("A.NAME=1");
    qnExpected.build();
    assertEquals(qn, qnExpected);
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:17,代碼來源:SqlParserTest.java

示例11: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
/**
 * C4,C5上隻存在倒排索引,單C4的選擇更高,選擇C4倒排
 */
@Test
public void testChooseIndex選擇倒排索引() {
    TableNode table = new TableNode("TABLE9");
    QueryTreeNode qn = table.query("C4=10&&C5>3");
    qn.build();

    IndexMeta index = IndexChooser.findBestIndex(table.getTableMeta(),
        table.getColumnsRefered(),
        toDNFFilter(table.getWhereFilter()),
        table.getTableName(),
        extraCmd);

    Assert.assertNotNull(index);
    Assert.assertEquals(index.getName(), "TABLE9._C4");
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:19,代碼來源:IndexChooserTest.java

示例12: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void test_order條件下推_子表_case3_不下推() {
    TableNode table1 = new TableNode("TABLE1");
    table1.alias("A");
    table1.orderBy("ID");
    table1.orderBy("NAME");
    table1.limit(0, 10);

    QueryNode query = new QueryNode(table1);
    query.orderBy("A.NAME");
    query.orderBy("A.SCHOOL");
    query.build();

    OrderByPusher.optimize(query);

    Assert.assertEquals(2, table1.getOrderBys().size());
    Assert.assertEquals("TABLE1.ID", table1.getOrderBys().get(0).getColumn().toString());
    Assert.assertEquals("TABLE1.NAME", table1.getOrderBys().get(1).getColumn().toString());
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:20,代碼來源:OrderByPusherTest.java

示例13: LENGTH

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void testQuery_函數別名() throws SqlParserException, QueryException {
    String sql = "SELECT T.ID , LENGTH(NAME) AS LEN FROM TABLE1 T  WHERE ID=1";
    QueryTreeNode qn = query(sql);
    qn.build();

    IFunction function = ASTNodeFactory.getInstance().createFunction();
    function.setColumnName("LENGTH(NAME)");
    function.setAlias("LEN");
    function.setFunctionName("LENGTH");

    QueryTreeNode qnExpected = new TableNode("TABLE1").alias("T").select("T.ID").query("ID=1");
    qnExpected.addColumnsSelected(function);
    qnExpected.build();
    assertEquals(qn, qnExpected);
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:17,代碼來源:SqlParserTest.java

示例14: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void test_where條件下推_多級join() {
    TableNode table1 = new TableNode("TABLE1");
    TableNode table2 = new TableNode("TABLE2");
    TableNode table3 = new TableNode("TABLE3");

    JoinNode join = table1.join(table2);
    join.select("TABLE1.ID AS ID , TABLE1.NAME AS NAME");
    join.query("TABLE1.ID>5 AND TABLE2.ID<10 AND TABLE1.NAME = TABLE2.NAME");
    join.build();

    JoinNode nextJoin = join.join(table3);
    nextJoin.query("TABLE1.NAME = 6 AND TABLE1.ID = TABLE3.ID");
    nextJoin.build();
    FilterPusher.optimize(nextJoin);

    Assert.assertEquals("(TABLE1.NAME = 6 AND TABLE1.ID > 5)", ((JoinNode) nextJoin.getLeftNode()).getLeftNode()
        .getWhereFilter()
        .toString());
    Assert.assertEquals("(TABLE2.ID < 10 AND TABLE2.NAME = 6)", ((JoinNode) nextJoin.getLeftNode()).getRightNode()
        .getWhereFilter()
        .toString());
    Assert.assertEquals("TABLE1.ID = TABLE3.ID", nextJoin.getJoinFilter().get(0).toString());
}
 
開發者ID:beebeandwer,項目名稱:TDDL,代碼行數:25,代碼來源:FilterPusherTest.java

示例15: TableNode

import com.taobao.tddl.optimizer.core.ast.query.TableNode; //導入依賴的package包/類
@Test
public void test_where條件下推_join列存在函數不處理() {
    TableNode table1 = new TableNode("TABLE1");
    TableNode table2 = new TableNode("TABLE2");

    JoinNode join = table1.join(table2);
    join.query("TABLE1.ID>5 AND TABLE2.ID<10 AND TABLE1.NAME = TABLE2.NAME + 1");
    join.build();
    FilterPreProcessor.optimize(join, true, null);
    FilterPusher.optimize(join);

    Assert.assertEquals("TABLE1.ID > 5", join.getLeftNode().getWhereFilter().toString());
    Assert.assertEquals("TABLE2.ID < 10", join.getRightNode().getWhereFilter().toString());
    Assert.assertEquals("TABLE1.NAME = TABLE2.NAME + 1", join.getWhereFilter().toString());// 還是留在where中
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:16,代碼來源:FilterPusherTest.java


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