可以指示 pg_dump 创建带有“IF NOT EXISTS”的表吗?

2024-03-11

正如标题所示。

我查看了手册页,似乎没有任何命令行参数可以在“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(使用前将#替换为@)

可以指示 pg_dump 创建带有“IF NOT EXISTS”的表吗? 的相关文章

随机推荐