postgresql语法检查而不运行查询
发布时间:2020-12-13 16:41:20 所属栏目:百科 来源:网络整理
导读:我想验证包含sql查询的文件的语法,然后才能在CVS项目中提交。 为了做到这一点,我有一个commitinfo脚本,但我无法找出sql命令是否有效。 psql似乎没有一个dryrun模式,并且从语法(即源)构建我自己的postgresql-dialact测试器似乎是一个漫长的延伸。 脚本可
我想验证包含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" (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |