zoukankan      html  css  js  c++  java
  • anltr 解析MYSQL

    String sql = "select a as c,b as s,'zhange' F, 1/5 as e from t_order";
    
            final MysqlQueryLexer mySqlLexer = new MysqlQueryLexer(CharStreams.fromString(sql));
    
            final CommonTokenStream commonTokenStream = new CommonTokenStream(mySqlLexer);
    
            final MysqlQueryParser mySqlParser = new MysqlQueryParser(commonTokenStream);
    
            mySqlParser.addParseListener(new MysqlQueryBaseListener());
    
            final MysqlQueryParser.SelectStatementContext selectStatementContext = mySqlParser.selectStatement();
            for (ParseTree child : selectStatementContext.children) {
                if (child instanceof MysqlQueryParser.SelectElementsContext) {
                    List<ParseTree>  columnElementContextList = ((MysqlQueryParser.SelectElementsContext) child).children;
                    for (int i = 0; i < columnElementContextList.size(); i++) {
                        ParseTree tree = columnElementContextList.get(i);
                        if (tree instanceof MysqlQueryParser.SelectColumnElementContext) {
                            MysqlQueryParser.SelectColumnElementContext columnElementContext = (MysqlQueryParser.SelectColumnElementContext) tree;
                            System.out.println(columnElementContext.fullColumnName());
                            System.out.println(columnElementContext.start.getText() + "----------" + columnElementContext.start.getType());
                            System.out.println(columnElementContext.stop.getText());
                        }
                    }
                }
                System.out.println(child.getText() + "------"  );
    
            }
    
  • 相关阅读:
    java面试题总汇
    数据库sql语句规则
    docker安装redis(网上很多答案都是错误的,小心误入歧途!)
    docker 安装redis后,可视化工具无法连接
    Session
    #{}和${}区别
    axios和ajax区别
    Git使用
    Git常用命令
    如何简单粗暴的搞定dubbo调用模块
  • 原文地址:https://www.cnblogs.com/masterZ/p/15126424.html
Copyright © 2011-2022 走看看