Re: Seeking Advice on Table Alterations without Downtime in PostgreSQL

Поиск
Список
Период
Сортировка
От Laurenz Albe
Тема Re: Seeking Advice on Table Alterations without Downtime in PostgreSQL
Дата
Msg-id b8359b9dc8b8ce7cb66477fcc7a993d9e6edfe5c.camel@cybertec.at
обсуждение исходный текст
Ответ на Seeking Advice on Table Alterations without Downtime in PostgreSQL  (Veerendra Pulapa <veerendra.pulapa@ashnik.com>)
Список pgsql-admin
On Mon, 2023-07-17 at 16:31 +0000, Veerendra Pulapa wrote:
> I am interested in techniques or approaches that allow for seamless alterations such
> as adding/removing columns, modifying column data types, renaming columns, and
> altering constraints.

Adding, dropping and renaming columns is always fast.
Unless you have long running transactions, they will never give you trouble.

Changing the column data type is only fast if the types are binary compatible,
for example varchar(20) -> varchar(100) or varchar(10) -> text.
Other than that, the table has to be rewritten.

To do that without down time, you could define an additional column with
the new data type, fill ot with the value from the old column and then
drop the old column.  This will cause bloat if you do it in a single
UPDATE, and constraints will require extra attention, but it is possible.

You cannot alter constraints in PostgreSQL.  You have to drop and re-create
them.

Yours,
Laurenz Albe



В списке pgsql-admin по дате отправления:

Предыдущее
От: Veerendra Pulapa
Дата:
Сообщение: Seeking Advice on Table Alterations without Downtime in PostgreSQL
Следующее
От: srinivas oguri
Дата:
Сообщение: Re: PostgreSQL 12 VS PostgreSQL 15