我想验证包含SQL查询的文件的语法,然后才能在CVS项目中提交。
为了做到这一点,我有一个commitinfo脚本,但我无法找出sql命令是否有效。 psql似乎没有一个dryrun模式,并且从语法(即源)构建我自己的postgresql-dialact测试器似乎是一个漫长的延伸。
脚本可能包含多个查询,因此EXPLAIN不能在其周围包裹。
任何提示?
我最近写了一个实用工具来静态地检查Postgresql的sql语法。它利用了用于postgres的嵌入式sql C预处理程序ecpg来检查sql语法,因此它使用与Postgres本身内置的完全相同的解析器。
您可以在github:http://github.com/markdrago/pgsanity上查看它。您可以给README一个滑动来更好地了解它的工作原理,并获取有关如何安装它的说明。以下是一个简单的例子,说明如何使用pgsanity:
$ pgsanity good1.sql good2.sql bad.sql bad.sql: line 1: ERROR: Syntax error at or near "bogus_token" $ find -name '*.sql' | xargs pgsanity ./sql/bad1.sql: line 59: ERROR: Syntax error at or near ";" ./sql/bad2.sql: line 41: ERROR: Syntax error at or near "insert" ./sql/bad3.sql: line 57: ERROR: Syntax error at or near "update"