Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: postgres, performance, count

В каких случаях SELECT COUNT(*) в Postgres может работать очень медленно?

Проверяет понимание работы СУБД и планов выполнения запросов.

Короткий ответ

COUNT(*) сканирует все строки таблицы, потому что Postgres не хранит счётчик строк. На больших таблицах без условий это может быть очень медленно.

Длинный ответ

В Postgres:

  • COUNT(*) читает каждую видимую строку;

  • MVCC не позволяет хранить точное количество строк заранее;

  • индекс не всегда помогает.

Медленно, если:

  • таблица большая (миллионы строк);

  • нет условий WHERE;

  • используется в realtime API.

Альтернативы:

  • приблизительное количество (pg_class.reltuples);

  • хранение счётчиков отдельно;

  • инкрементальные агрегаты;

  • фоновые джобы.

Вывод: COUNT(*) в API — почти всегда плохая идея.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    4

  • Сложность:

    5

Навыки

  • Postgres

    Postgres

Ключевые слова

#postgres

#performance

#count

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.