【发布时间】:2013-11-19 17:56:27
【问题描述】:
更新:此特定问题与 psql 包含的脚本无关。包含的脚本中的变量按预期进行插值。实际问题是由于在 SQL 函数定义中的 $$ 引号内使用 psql 变量导致的,并且是 described in this question。
我正在使用 psql 变量在相当长的 SQL 脚本中从命令行设置一些参数(表名、值)。脚本变得太长了,我将它分成几个部分,并使用\ir subscript.sql 语法将它们包含在主脚本中。但是,主脚本中的变量不会传递给下标。这很奇怪,因为文档说\i file 相当于在键盘上键入文件,即应该保留脚本环境。
有没有一种简单的方法可以将变量传递给 psql 中包含的脚本?
我使用的是 psql 版本 9.3.1。
【问题讨论】:
-
您所描述的应该可以正常工作。你能展示一个可重现的例子吗?
-
糟糕!我试图创建一个可重现的示例,并意识到问题实际上是变量没有插入到 SQL 函数定义中的 $$ 引号内。在包含的脚本中,psql 变量被正确插入。
标签: postgresql scripting psql postgresql-9.3