
image.png
按照Oracle文件夹里的说明https://github.com/mysql/mysql-workbench/tree/8.0/library/parsers/grammars
, 根据生成命令生成的C++代码,如果把-Dlanguage改成Java,生成的代码中少了一些抽象类.
按照Positive Technologies文件夹https://github.com/antlr/grammars-v4/tree/master/sql/mysql/Positive-Technologies
里的MySqlLexer.g4和MySqlParser.g4根据命令生成Java代码,命令如下:
java -jar ./antlr-4.8-complete.jar -Dlanguage=Java -listener -visitor -o ./mysql-parser -package com.mysql.parser MySqlLexer.g4 MySqlParser.g4
测试:
String sql = "select a.id from t_order a straight_join t_product b on a.productId = b.id".toUpperCase();
final MySqlLexer mySqlLexer = new MySqlLexer(CharStreams.fromString(sql));
final CommonTokenStream commonTokenStream = new CommonTokenStream(mySqlLexer);</
本文介绍了使用ANTLR4解析MySQL语法的方法,通过对比Oracle和Positive Technologies提供的Grammar,展示了如何生成Java代码并进行测试。同时,文章讨论了ShardingSphere、JSqlParser和阿里Druid在解析SQL上的特点,包括解析效率、对象层次和扩展性。
最低0.47元/天 解锁文章
1022

被折叠的 条评论
为什么被折叠?



