当前位置:  开发笔记 > 编程语言 > 正文

Java的SQL解析器库

如何解决《Java的SQL解析器库》经验,为你挑选了5个好方法。

是否有用于解析SQL语句的开源Java库?

如果可能,它应该是可定制的或足够灵活的,以便能够解析(或至少忽略)特定于供应商的语法(例如Oracle表空间定义或MySQL的LIMIT子句).

如果没有,严格遵守SQL标准也没关系.

更新:我需要两件事:

为非SQL数据库提供SQL接口(映射到内部API调用)

在SQL进入实际数据库之前重写SQL(例如Oracle)

duffymo.. 51

ANTLR3具有ANSI SQL语法.您可以使用它来创建自己的解析器.

ANTLR4有一个SQL语法.



1> duffymo..:

ANTLR3具有ANSI SQL语法.您可以使用它来创建自己的解析器.

ANTLR4有一个SQL语法.


为什么在使用ANTLR时生成自己的解析器生成器?
为什么在实现自己的解析器生成器时使用ANTLR?

2> David Philli..:

JSqlParser

Presto的解析器是使用ANTLR4编写的,并且有自己的不可变AST类,它们是从解析器构建的.AST有一个访客和漂亮的打印机.



3> Elijah..:

分析器

如果你需要一个解析器,Apache Derby的代码库中应该有一个解析器.

处理特定于供应商的SQL

您可能希望查看jdbc Connection对象上的.native()方法,您可以将其传递给供应商中立查询,这些查询将被后处理为特定于供应商的查询.



4> 小智..:

一般的SQL Parser for Java不是开源的,但正是您所关注的.



5> jagamot..:

试试Zql


zql适用于基本查询,但是当您尝试解析包含join语句的查询时,它会爆炸.所以我不建议
推荐阅读
赛亚兔备_393
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有