нагрузка больше чем на тестовом стенде?
pg-шный планировщик ничего не знает про нагрузку (афаик)... т.е. при прочих равных, при большой нагрузке и при малой выберет один и тот же план. а, ну единственное, под нагрузкой у вас visibility maps могут оказаться не обновлены, и вы вместо index-only scan получите index scan. Ну выключите автовакуум временно для эмуляции :)
я про такие вещи как например не 100к записей, а пару миллионов, и т.д.
а, статистику типа фейковую подсунуть? это да, было бы интересно...
а если пересчитать с низким defaul_statistics_target, мб она менее точной станет?)
ну менее точной, но в количестве строк на два порядка не ошибётся.
ну уехавшая стата и нагрузка-таки разные вещи. можно попробовать стейдж при типовой нагрузке придушить по процам и памяти. хз, правда, что это покажет)
А что Вам мешает (под superuser), если это всё равно тестовый сервер: UPDATE pg_class SET relpages = 200, reltuples = 232132 WHERE relname = 'a table name'; ну и так далее (есть и штатное средство для одной статистики — см. n_distinct в https://www.postgresql.org/docs/current/sql-altertable.html )? Базу поcле таких экспериментов лучше сжечь перезалить, на всякий случай. ;)
что делают эти параметры?
См. https://www.postgresql.org/docs/current/using-explain.html Ну и там ещё описаны статистики, являющиеся фундаментом планирования — всё это можно поменять таким способом, насколько я помню (но вот писать MCV и гистограммы вручную — это морока, конечно... с другой стороны, их можно откуда-то содрать (если есть, откуда... например, если тест — это в 1000 раз уменьшенный (каким-то образом) production, то можно содрать оттуда)).
Обсуждают сегодня