postgreSQL одновременно изменяет тип столбца с int на bigint
у меня довольно большая таблица (около 1 миллиарда строк), и мне нужно обновить тип id из SERIAL
to BIGSERIAL
; угадайте почему?:).
В основном это можно сделать с помощью этой команды:
execute "ALTER TABLE my_table ALTER COLUMN id SET DATA TYPE bigint"
тем не менее, это заблокировало бы мой стол навсегда и отложило мой веб-сервис.
есть довольно простой способ сделать эту операцию одновременно (независимо от времени это займет)?
1 ответов
Если у вас нет внешних ключей, указывающих ваш id, вы можете добавить новый столбец, заполнить его, удалить старый и переименовать новый в старый:
alter table my_table add column new_id bigint;
begin; update my_table set new_id = id where id between 0 and 100000; commit;
begin; update my_table set new_id = id where id between 100001 and 200000; commit;
begin; update my_table set new_id = id where id between 200001 and 300000; commit;
begin; update my_table set new_id = id where id between 300001 and 400000; commit;
...
create unique index my_table_pk_idx on my_table(new_id);
begin;
alter table my_table drop constraint my_table_pk;
alter table my_table alter column new_id set default nextval('my_table_id_seq'::regclass);
update my_table set new_id = id where new_id is null;
alter table my_table add constraint my_table_pk primary key using index my_table_pk_idx;
alter table my_table drop column id;
alter table my_table rename column new_id to id;
commit;