本文整理匯總了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());
}
示例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());// 下推成功
}
示例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());
}
示例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");
}
示例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);
}
示例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;
}
示例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");
}
示例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);
}
示例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異常
}
}
示例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);
}
示例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");
}
示例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());
}
示例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);
}
示例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());
}
示例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中
}