正如标题所示。
我查看了手册页,似乎没有任何命令行参数可以在“CREATE TABLE”语句中包含“IF NOT EXISTS”子句。
不,最接近的那个pg_dump就内置选项而言,这是--if-exists
,它只能与--clean
,意思是only适用于类似的事情DROP
命令。
如果你想添加这类东西,我认为你最好的选择是后期处理转储(假设您要转储到纯SQL而不是二进制格式)。为了涵盖所有各种情况,从技术上讲,您需要一个正则表达式来涵盖这部分CREATE TABLE http://www.postgresql.org/docs/current/static/sql-createtable.html命令语法:
CREATE [ [ GLOBAL | LOCAL ] { TEMPORARY | TEMP } | UNLOGGED ] TABLE
[ IF NOT EXISTS ] table_name
然而,更简单的正则表达式可能会涵盖大多数情况(例如,我认为您不会转储临时表,几乎在定义上,因此可以忽略该部分)。相似地,GLOBAL
and LOCAL
已弃用,因此也可以安全地忽略它们,具体取决于您的数据。
pg_dump 文档 http://www.postgresql.org/docs/current/static/app-pgdump.html以供参考。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)