Postgres:执行 SQL 文件时退出代码非零?

Postgres:执行 SQL 文件时退出代码非零?

我正在编写一个 shell 脚本,它使用两种形式调用 psql...一种是通过命令 (-c),另一种是通过文件 (-f)。

例如 psql -c“创建表 foo (bar 整数)”

psql -f foobar.sql

这些形式之间的一个区别是,如果遇到错误,命令调用(-c)将返回非零退出代码,而文件调用(-f)似乎总是返回零。

我想知道是否有解决此行为的方法?(即,如果在执行文件时发生错误则返回非零)。

谢谢。

答案1

您可以使用以下语句。

psql -v ON_ERROR_STOP=1 -f foobar.sql

即使文件顶部foobar.sql未启用该文件,这也将返回正确的返回代码。ON_ERROR_STOP

答案2

我找到了解决这个问题的方法。

我需要ON_ERROR_STOP在文件顶部启用。

例子:

\set ON_ERROR_STOP true

相关内容