Java的SQL解析器库[关闭]

问题

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

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

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

**更新:**我需要两件事:

  • 为非SQL数据库提供SQL接口(映射到内部API调用)
  • 在SQL进入实际数据库之前重写SQL(例如Oracle)

#1 热门回答(46 赞)

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

ANTLR4的aSQL grammar


#2 热门回答(29 赞)

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

#3 热门回答(10 赞)

分析器
如果你需要一个解析器,那么代码库中应该有一个解析器.Apache Derby
处理特定于供应商的SQL
你可能希望查看jdbc Connection对象上的2151515方法,你可以将其传递给供应商中性查询,这些查询将被后处理为特定于供应商的查询。