首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >重命名postgres表会删除现有索引吗?

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

Stack Overflow用户
提问于 2017-06-28 14:55:04
回答 1查看 3.9K关注 0票数 5

我正在开发一个ETL,我们从hive获取数据并将其转储到Postgres。为了确保数据不会损坏,我首先将数据存储在一个临时表中(创建为具有所有索引和约束的主表),如果数据通过验证,则将其复制到主表中。但由于数据量巨大,这需要很长时间。一旦验证了数据,我现在正在考虑删除主表,然后将临时表重命名为主表。

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-28 15:03:52

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

代码语言:javascript
运行
复制
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)
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44795536

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档