package com.alibaba.druid.bvt.sql.schemaStat; import com.alibaba.druid.sql.SQLUtils; import com.alibaba.druid.sql.ast.SQLStatement; import com.alibaba.druid.sql.parser.SQLParserUtils; import com.alibaba.druid.sql.parser.SQLStatementParser; import com.alibaba.druid.sql.visitor.SchemaStatVisitor; import com.alibaba.druid.util.JdbcConstants; import junit.framework.TestCase; import org.junit.Assert; public class SchemaStatTest8 extends TestCase { public void test_schemaStat() throws Exception { String sql = "SELECT * FROM AQLQCAT " + "JOIN AQLQCATB " + " ON AQLQCAT.ZZ = AQLQCATB.RR " + " AND trim(AQLQCAT.BB) = AQLQCATB.DD " + "WHERE AQLQCAT.MANDT = 'A0' " + " AND AQLQCATB.NUM = 'A1'"; String dbType = JdbcConstants.ORACLE; SQLStatementParser parser = SQLParserUtils.createSQLStatementParser(sql, dbType); SQLStatement stmt = parser.parseStatementList().get(0); SchemaStatVisitor statVisitor = SQLUtils.createSchemaStatVisitor(dbType); stmt.accept(statVisitor); // System.out.println(statVisitor.getColumns()); // System.out.println(statVisitor.getGroupByColumns()); // group by System.out.println("relationships : " + statVisitor.getRelationships()); // group by Assert.assertEquals(6, statVisitor.getColumns().size()); Assert.assertEquals(6, statVisitor.getConditions().size()); } }