Переименование таблицы postgres удалит существующие индексы?

Я работаю над ETL, где мы получаем данные из улья и отправляем их в Postgres. Просто, чтобы гарантировать, что данные не повреждены, я сначала сохраняю данные во временной таблице (созданной как основная таблица со всеми индексами и ограничениями) и, если данные проверены, копирует их в основную таблицу. Но это заняло много времени, так как данные огромны. Как только данные проверены, я думаю о том, чтобы удалить основную таблицу и затем переименовать временную таблицу в основную таблицу.

Будет ли переименование таблицы в Postgres отбрасывать определенные для нее индексы, ограничения и значения по умолчанию?

1 ответ

Решение

Это слово - нет, оно не будет сбрасывать индексы, ограничения или значения по умолчанию. Вот короткая демонстрация:

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)
Другие вопросы по тегам