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

标签 postgresql database-design ddl table-rename

我正在研究 ETL,我们从 Hive 获取数据并将其转储到 Postgres。为了确保数据不损坏,我首先将数据存储在一个临时表中(创建为具有所有索引和约束的主表),如果数据经过验证,则将其复制到主表。 但由于数据庞大,它已经花费了很长时间。 验证数据后,我现在正在考虑删除主表,然后将临时表重命名为主表。

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

最佳答案

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

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)

关于postgresql - 重命名 postgres 表会删除现有索引吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44795536/

相关文章:

sql - 将获取/创建存储过程从一项推广到多项

database-design - 在 2 列上建立索引和在每一列上分别建立索引有什么区别?

database-design - 设计问题

sql - PostgreSQL:授予用户对 PostgreSQL 数据库的所有权限

sql - PostgreSQL 函数数字类型错误

postgresql - centos5 postgresql客户端

ruby-on-rails - Rails 没有为新记录分配唯一 ID

postgresql - 如何在 Postgres 的表中索引子组?

sql - 多个数据库表或合并为一个

oracle - 如果我有包含相同值的行,我应该如何链接主键和外键?