重命名PostgreSQL表会删除现有的索引吗?

8
我正在处理一个ETL项目,从Hive中获取数据并将其转储到Postgres。为了确保数据不会损坏,我首先将数据存储在临时表中(该表是带有所有索引和约束的主表),如果数据经过验证,则将其复制到主表中。 但由于数据量很大,这需要很长时间。 一旦数据经过验证,我现在考虑删除主表,然后将临时表重命名为主表。
在Postgres中重命名表是否会删除表上定义的索引、约束和默认值?

1
另一种方法是保留两个表并使用视图(我认为PostgreSQL不支持同义词)作为指向临时数据正确表和实时数据正确表的指针。 - David Aldridge
1个回答

7

它是一个单词,不会删除任何索引、约束或默认值。这是一个快速演示:

db=> CREATE TABLE mytab (
id INT PRIMARY KEY,
col_uniq INT UNIQUE,
col_not_null INT NOT NULL DEFAULT 123
);
CREATE TABLE
db=> \d mytab
             Table "public.mytab"
    Column    |  Type   |      Modifiers       
--------------+---------+----------------------
 id           | integer | not null
 col_uniq     | integer | 
 col_not_null | integer | not null default 123
Indexes:
    "mytab_pkey" PRIMARY KEY, btree (id)
    "mytab_col_uniq_key" UNIQUE CONSTRAINT, btree (col_uniq)

db=> ALTER TABLE mytab RENAME TO mytab_renamed;
ALTER TABLE
db=> \d mytab_renamed
         Table "public.mytab_renamed"
    Column    |  Type   |      Modifiers       
--------------+---------+----------------------
 id           | integer | not null
 col_uniq     | integer | 
 col_not_null | integer | not null default 123
Indexes:
    "mytab_pkey" PRIMARY KEY, btree (id)
    "mytab_col_uniq_key" UNIQUE CONSTRAINT, btree (col_uniq)

触发器怎么样?如果表被重命名,它们会受到什么影响? - Reinsbrain

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接