Назад к вопросам
Senior
10
Что такое bloating в PostgreSQL и почему физический размер таблицы растёт даже после удаления данных?
Компании, где спрашивали
Позитив Технолоджис
Ответ от нейросети
sobes.tech AI
В PostgreSQL "bloating" — это ситуация, когда физический размер таблицы или индекса растёт из-за накопления «мертвых» строк (dead tuples), которые остаются после обновлений или удалений данных. PostgreSQL использует MVCC (многоверсионность), поэтому при удалении или обновлении старые версии строк не удаляются сразу, а помечаются как устаревшие.
Из-за этого физический размер таблицы не уменьшается автоматически после удаления данных. Чтобы освободить место, нужно запускать команду VACUUM, которая очищает мёртвые строки, или VACUUM FULL, которая дополнительно сжимает таблицу и возвращает место ОС.
Пример:
-- Удаляем данные
DELETE FROM my_table WHERE condition;
-- Освобождаем место
VACUUM my_table;
-- Или для более агрессивного сжатия
VACUUM FULL my_table;
Без регулярного вакуума таблица будет расти, что негативно влияет на производительность и использование диска.