百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

antlr实现解析sql语法树-检测sql是否与数据库字段匹配

xsobi 2024-12-06 20:28 1 浏览

前言

  • 你有没有想过 idea 是如何做到sql 关键字语法高亮的?毫无疑问需要识别出sql 的关键字。

antlr

  • antlr 就是这么一个工具,他能够解析sql ,下面我们通过他来实现表名的获取

安装

antlr-tools

  • 首先我们下载上面的antlr 工具 , 然后再通过工具分析每种sql 的语法,每种sql的语法需要我们额外准备,你可以自己将sql 的语法编写好,这里我就直接使用官方提供的语法了。

sql语法

bash复制代码 git clone https://github.com/antlr/grammars-v4.git
  • 在开始sql解析之前,我们先将焦点移到antlr , antlr 是一个语法解析器工具,sql只是其中一个解析,所以我们先开始一段简单的语法解析吧。

安装文档

windows安装

  • 上方文档我们移动到windows章节,首先antlr需要java环境,然后将上方我们下载antlr-4.11.1-complete.jar配置到环境变量中。官网也提到了配置环境变量可以在终端中临时配置也可以在系统环境变量中永久配置。

临时配置环境变量

  • 在终端中执行 SET CLASSPATH=.;C:\Javalib\antlr-4.11.1-complete.jar;%CLASSPATH% 即可在终端中临时设置了变量。

永久配置环境变量

  • 这样配置只要是新打开的终端都是可以获取到CLASSPATH 这个环境变量的。

小结

  • 这里需要注意的是,在配置CLASSPATH这个环境变量时必须配置 . , 如果不配置在执行到grun命令时会报错Can't load Hello as lexer or parser。

antlr4&&grun

  • 因为antrl4基于java包,每次运行要从java调用,为了方便使用写一个批处理文件(.bat文件)放在antlr-4.11.1-complete.jar同一文件夹下,自己命名,我命名为antlr4.bat
  • 为了能够访问我们的自定义脚本,这里我们需要将antlr-4.11.1-complete.jar所在目录配置成环境变量。我这里是E:/study/antlr/antlr-4.11.1-complete.jar
  • 然后我们就可以在E:\study\antlr的目录下新建一个脚本antlr4.bat , 内容如下
ini复制代码 doskey antlr4=java org.antlr.v4.Tool $*
 doskey grun=java org.antlr.v4.gui.TestRig $*
  • 这样我们可以执行antlr4.bat命令后就可以在终端执行antlr4&&grun命令了。官网也介绍到我们可以分别为antlr4和grun创建脚本

antlr4.bat

erlang复制代码 java org.antlr.v4.Tool %*

grun.bat

ini复制代码 @ECHO OFF
 SET TEST_CURRENT_DIR=%CLASSPATH:.;=%
 if "%TEST_CURRENT_DIR%" == "%CLASSPATH%" ( SET CLASSPATH=.;%CLASSPATH% )
 @ECHO ON
 java org.antlr.v4.gui.TestRig %*

测试

  • 到了这里我们的antlr4已经安装完成了,那么我们该如何进行语法测试呢?
ini复制代码 grammar Hello;               // 1、定义文法的名字
 
 s  : 'hello' ID ;            // 3、匹配关键字hello和标志符
 ID : [a-z]+ ;                // 标志符由小写字母组成
 WS : [ \t\r\n]+ -> skip ;    // 4、跳过空格、制表符、回车符和换行符
  • 下面针对语法进行相关解释:
  1. 定义了 grammar 的名字,名字需要与文件名对应
  2. s定义的语法,会使用到下方定义的正则表达式词法
  3. 定义了空白字符,后面的 skip 是一个特殊的标记,标记空白字符会被忽略。
ini复制代码 grammar Hello;
 r  : 'hello' ID ;
 ID : [a-z]+ ;
 WS : [ \t\r\n]+ -> skip ;

打开终端

  • 针对新打开的终端我们执行antlr4 就会执行我们配置的E:\study\antlr\antlr4.bat 脚本。执行完成之后就可以执行内部命令了。
  • 通过antlr4 Hello.g4进行语法翻译
  • 会生成一些Java类,这些类就是我们用来解析相关文本的工具类。为了能够执行这些Java 我们先 javac编译一下
复制代码 javac Hello*.java

grun解析

  • 下面我们通过grun进行demo解析
复制代码 grun Hello r -tree
  • 如下命令就会进行等待我们输入文本。Hello.g4的语法就是 hello [a-z]+ 这个正则,也就是所有的hello开头的文本,中间一个空格后面跟着由小写字母组成的字符的整个文本就会被解析出来。

(注意:^D在 Unix 上表示 control-D 并表示“输入结束”;^Z在 Windows 上使用。)

Linux安装

  • windows是大多数人使用的系统,但是Linux才是最终的服务环境,加之我本身就是Linux作为开发环境,所以Linux安装对于我而言很重要。
  • 因为antlr本事就是jar ,得以与java的跨平台所以这里资源两个系统是可以通用的。
  • linux上配置环境变量更方便,我们只需要在~/.bashrc或者~/.zshrc中配置即可
bash复制代码 export CLASSPATH=".:/home/zxhtom/zxh/antlr/antlr-4.11.1-complete.jar:$CLASSPATH"
  • 在终端中给命令创建别名
ini复制代码 alias antlr4='java -Xmx500M -cp "/home/zxhtom/zxh/antlr/antlr-4.11.1-complete.jar:$CLASSPATH" org.antlr.v4.Tool'
 alias grun='java -Xmx500M -cp "/home/zxhtom/zxh/antlr/antlr-4.11.1-complete.jar:$CLASSPATH" org.antlr.v4.gui.TestRig'
  • 或者我们也可以按照windows方式的命令,其实最终都是执行相同的类
ini复制代码 alias antlr4='java org.antlr.v4.Tool '
 alias grun='java org.antlr.v4.gui.TestRig'
  • export和alias可以同时配置在~/.zshrc中。

可视化

  • TestRig充当一款调试工具,官网建议我们将它重命名为grun
  • 直接输入grun可以看到其支持的参数。

参数

功能

-tokens

打印出词法符号流

-tree

LISP格式打印分析树,啥叫LISP?

-gui

可视化打印分析树

-ps fiels.ps

以PostScript格式生成可视化语法分析树

-trace

打印规则的名字以及进入和离开该规则时的语法符号

  • 不管是linux还是windows我们都可以通过 -gui的方式进行可视化

自定义解析

  • 从4.11开始,antlr大约支持10种语言进行语法解析,上面案列中我使用的是Java 语言的解析工具,只需要javac编译一次即可,或者直接将相关的Java代码拷贝到项目中进行调用。下面我们看看如何生成Python语言的解析代码吧。

python

复制代码 pip3 install antlr4-python3-runtime
  • 因为是测试python的语法生成,这里就不配置快捷命令了,所以这里使用全命令java -jar ../antlr-4.11.1-complete.jar -Dlanguage=Python3 Hello.g4
ini复制代码 import sys
 from antlr4 import *
 from HelloLexer import HelloLexer
 from HelloParser import HelloParser
 
 
 def main(argv):
     input = FileStream(argv[1])
     lexer = HelloLexer(input)
     stream = CommonTokenStream(lexer)
     parser = HelloParser(stream)
     tree = parser.r()
     print(tree.toStringTree(recog=parser))
 
 if __name__ == '__main__':
     main(sys.argv)
 
  • 上述代码就是我们对antlr生成的解析代码的使用,这样我们可以进行自定义的处理。

解析Mysql

xml复制代码 <dependency>
     <groupId>org.antlr</groupId>
     <artifactId>antlr4</artifactId>
     <version>4.11.1</version>
 </dependency>
  • 版本需要保持一致。
  • 上一章节中我们通过一个简单的Hello.g4语法进行Java、python等语言的解析代码的生成。上章节也提到antlr是一个语法解析工具,并不仅仅是解析sql , 理论上他能解析所有的语法,比如你自己有一套语法如何让antlr解析呢?你只需要按照antlr的规则用antlr的语言表达出你自己的语法,目前比较规范的就是https://github.com/antlr/grammars-v4.git这个仓库提供的语法解析树了,本次对mysql解析也是使用这个仓库下提供的g4 文件。
  • 这个仓库给我们提供了MySqlLexer.g4和MySqlParser.g4两个文件,前者是Mysql的关键词,后者就是Mysql的语法配置。examples是作者给我们提供的Mysql相关的sql 。 我们可以用来测试用。
  • 为了方便测试,这里我们将这两个g4文件拷贝到其他目录下执行生成Java解析代码
复制代码 antlr4 MySqlParser.g4 MySqlLexer.g4
  • 两个文件没有先后顺序区别,但是要注意的是不能缺少。笔者就是一开始认为只需要MysqlParser.g4一再在报错。MySqlParser.g4:2595:37: cannot create implicit token for string literal in non-combined grammar: '|'。
  • 执行完上述命令后,我们就可以看到我们的Java代码了.
  • 这样的代码是没有包名的,好在antlr在生成代码时支持指定包名。antlr4 MySqlParser.g4 MySqlLexer.g4 -package com.github.zxhtom.mysql


作者:zxhtom
链接:https://juejin.cn/post/7246177710728282169

相关推荐

【互联网那些事】高效开发Android App的10个建议

  假如要GooglePlay上做一个最失败的案例,那最好的秘诀就是界面奇慢无比、耗电、耗内存。接下来就会得到用户的消极评论,最后名声也就臭了。即使你的应用设计精良、创意无限也没用。  耗电或者内存...

手机APP开发方式有哪些? 手机app的开发模式有哪三种?

微信小程序开发定制_软件开发_APP开发_网站制作-优软软件开发...

Android开发入门(一):Android系统简介

Android系统是Google公司在2008年推出的一款智能移动设备操作系统,通过不断地版本迭代,目前已经推出到Android11版本了。Android系统广泛应用在手机、平板、电视等各种电子设...

物联网app开发流程 物联网app开发工具

现在随着科技的发展,很多产品都想用一个手机app去显示他的参数数据或者通过手机app去控制它。但是很多人不知道他的流程。今天我就来说下物联网app开发流程。首先需要把物联网app开发流程分2个步骤,一...

Android开发进阶 | 如何学习 Android Framework?

大部分有“如何学习Framework源码”这个疑问的,应该大都是应用层开发。应用层是被Framework层调用执行的,知道自己的代码是怎么被调用的,才能理解程序的本质,理解本质有助于解决遇到的...

快速实现APP混合开发(Hybrid App开发)攻略

前言:...

三个阶段带你了解一款app开发的完整流程

第一个阶段需求阶段:1.需求讨论--开发类型、开发平台、具体的产品功能需求、项目预计完成时间、预算2.需求评估--确认合作后评估具体的预算3.界面设计--设计部门进行产品界面设计,形成效果图...

Android 开发中文引导-应用小部件

应用小部件是可以嵌入其它应用(例如主屏幕)并收到定期更新的微型应用视图。这些视图在用户界面中被叫做小部件,并可以用应用小部件提供者发布。可以容纳其他应用部件的应用组件叫做应用部件的宿主(1)。下面的截...

手机软件开发从零开始【Android第2篇Hello】

Hello,朋友们我们又见面了。上一篇我们讲到了《Android开发环境搭建【Android基础第1篇】》,错过的朋友可以点击文章末尾的“阅读原文”查看。另外需要下载JDK和ADT-bundle工具的...

「全栈工程师之梦的开始--安卓开发(二)」开发安卓app

在配置好jdk开发环境、安装好开发工具Androidstudio后,我们就可以开始开发安卓app了。首先,我们需要先了解下android的术语。...

二、Android界面开发 android 开发

学习目标了解Android常用布局了解Android常用控件...

如何开发一款APP既快捷也简便 开发一款app的步骤

具体较为简单的步骤可以选择用androidstudio开发app1、打开软件,在菜单中选择file-》newproject打开创建向导。2、配置项目,确定各个名称和存放项目的存放路径;Applic...

安卓开发中的“Android高手”,需要具备哪些技术?

前言成为一名安卓开发者很容易,但是要成为一名“Android高手”却不那么容易;...

移动开发(一):使用.NET MAUI开发第一个安卓APP

对于工作多年的C#程序员来说,近来想尝试开发一款安卓APP,考虑了很久最终选择使用.NETMAUI这个微软官方的框架来尝试体验开发安卓APP,毕竟是使用VisualStudio开发工具,使用起来也...

微软推出PowerApps:零基础开发Win10/iOS/安卓企业应用

IT之家讯微软今天面向企业宣布了全新的应用开发解决方案PowerApps,让Windows(包括Win10)、iOS以及安卓应用的开发和分发变得更加简单。PowerApps的用户界面与Office办...