postgresql语法检查而不运行查询

postgresql语法检查而不运行查询,第1张

概述我想验证包含sql查询的文件的语法,然后才能在CVS项目中提交。 为了做到这一点,我有一个commitinfo脚本,但我无法找出sql命令是否有效。 psql似乎没有一个dryrun模式,并且从语法(即源)构建我自己的postgresql-dialact测试器似乎是一个漫长的延伸。 脚本可能包含多个查询,因此EXPLAIN不能在其周围包裹。 任何提示? 我最近写了一个实用工具来静态地检查Postg 我想验证包含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.sqlbad.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"
总结

以上是内存溢出为你收集整理的postgresql语法检查而不运行查询全部内容,希望文章能够帮你解决postgresql语法检查而不运行查询所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1171382.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存