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

rai*_*zsh 5 postgresql ddl database-design table-rename

我正在开发一个ETL,我们从蜂巢中获取数据并将其转储到Postgres。为了确保数据没有损坏,我首先将数据存储在一个临时表(使用所有索引和约束创建为主表)中,如果数据经过验证,则将其复制到主表中。但是,只要数据量巨大,就已经花费了很长时间。数据通过验证后,我现在考虑删除主表,然后将临时表重命名为主表。

在Postgres中重命名表格会删除在其上定义的索引,约束和默认值吗?

Mur*_*nik 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)
Run Code Online (Sandbox Code Playgroud)