Ssylka

Нестабильность статистики PostgreSQL и альтернативный сборщик

Стандартный сборщик статистики PostgreSQL может приводить к нестабильности планов запросов из-за стохастической природы сбора данных. Даже увеличение параметра default_statistics_target не гарантирует стабильности, особенно для полей с большим количеством дубликатов. Это затрудняет воспроизводимость бенчмарков и сравнительный анализ результатов.

Флуктуации в оценках количества строк, выбираемых из таблицы, могут начинаться уже на стадии SeqScan. Оценка выражений вида x = ANY (...) основывается на суммировании вероятностей для каждого элемента. Даже небольшие изменения частотности элементов выборки могут приводить к изменениям в итоговых оценках и, как следствие, к смене плана запроса.

В качестве решения предлагается создать расширение для PostgreSQL, которое позволит реализовать более точный сбор статистики, проходя всю таблицу и подсчитывая количество различных значений (ndistinct) и MCV. Расширение может цепляться к SeqScan нодам запросов через CustomScan. При этом можно будет использовать два хука get_relation_stats_hook и get_index_stats_hook для подмены стандартной статистики.

Такое расширение позволит реализовать предикатную статистику и более эффективно управлять статистикой для партиционированных таблиц. Также, можно будет использовать индексы для упрощения вычислений и реализовывать иные алгоритмы выборки. Хранение статистики может быть организовано в отдельной таблице pg_statistic_extra.


Новое на сайте

8093Эволюционный лабиринт: путь от примата к человеку разумному 8092Объектно-ориентированное рисование фигур в GIMP Script-Fu 8091Цифровая революция на запястье: выбор между умом и классикой 8090Кто же на самом деле виноват в скандале вокруг фильма "Это кончается нами"? 8089Authentik как SSO-решение: настройка для Spring Boot 8087Космическая гонка со временем: астероид 2024 YR4 и Земля на перепутье 8086Пионеры дорог: как "Руссо-Балт" открыл эру российского автопрома 8085Сейсмическая тревога: санторини дрожит, но вулкана не боится 8084Цифровые экосистемы: ловушка для пользователей и прибыль для корпораций 8083Могло ли переутомление диспетчеров стать причиной трагедии в небе над Вашингтоном? 8082Ледяные города северного моря: затерянные ландшафты древних гигантов 8081Эпоха золотого звука: почему «бриг 001» возглавляет рейтинг винтажной аудиотехники 8080От динамической памяти к обучению Хебба: новый взгляд на импульсные нейросети 8079Новая этика и Четвёртый закон робототехники: ASI-агенты и Инференс