postgresql语法检查而不运行查询

前端之家收集整理的这篇文章主要介绍了postgresql语法检查而不运行查询前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想验证包含SQL查询文件的语法,然后才能在CVS项目中提交。

为了做到这一点,我有一个commitinfo脚本,但我无法找出sql命令是否有效。 psql似乎没有一个dryrun模式,并且从语法(即源)构建我自己的postgresql-dialact测试器似乎是一个漫长的延伸。

脚本可能包含多个查询,因此EXPLAIN不能在其周围包裹。

任何提示

我最近写了一个实用工具来静态地检查Postgresqlsql语法。它利用了用于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"

猜你在找的Postgre SQL相关文章