antlr4 mysql_Antlr4解析MySQL语法使用方法

df256de737b4

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);

final MySqlParser mySqlParser

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值