为了做到这一点,我有一个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语法检查而不运行查询所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)