172 похожих чатов

>> Вы же не сравнивали, сознайтесь? 😉 Изначально таблицы не были

партицированы, и в течении какого-то времени скорость выполнения запросов проседала, в какой-то момент до неприемлемого уровня. Партицирование ввел всего для 3х таблиц и это дало серьезный буст производительности - от индексов такого получить не удалось. Пруфов предоставить прямо сейчас не могу, т.к. нужно искать и разворачивать где-нибуть старый дамп бд + найти свободную машину, но то, что partition pruning работает на моих запросах с ограничением по диапазону времени уверен. Суммарный объем записей около 120млн на таблицу, на партишен за последнее время около 1.3млн, так что партицирование позволяет даже без индексов сузить диапазон с 120млн до 5млн для большинства запросов, и мне кажется это неплохой результат.

>> возможно, стоило подумать, какой "физический" порядок записей лучше подходит для большинства запросов и сделать CLUSTER

Насколько я понял документацию, в postgresql нет clustered table, а операция cluster выполняет одноразовое упорядочивание данных в таблице. Я могу сказать, что практически все запросы к этим таблицам запрашивают данные за последние 3-4 недели/месяца - а обновляются как раз в основном данные за 3-4 последних месяца.

Пойду курить pg_partman, спасибо

ps. c tl;dr промазал, бывает

1 ответов

10 просмотров

> Партицирование ввел всего для 3х таблиц и это дало серьезный буст производительности - от индексов такого получить не удалось. Кхе-кхе, возможно, Вам не удалось? ;) Ладно, это, вполне возможно, всего лишь придирки — Вам "на месте" оно виднее, конечно. > но то, что partition pruning работает на моих запросах с ограничением по диапазону времени уверен. Вопрос не в том, работает он или нет, и в том, насколько он хорош по сравнению и индексацией. Ладно, это "лирика". Сделали, стало лучше — и хорошо. :) > Насколько я понял документацию, в postgresql нет clustered table, Да. > а операция cluster выполняет одноразовое упорядочивание данных в таблице. И да. Но то-то и оно — Вы что, собираетесь менять (а если, собираетесь — насколько часто?) "старые" данные? ;) > Я могу сказать, что практически все запросы к этим таблицам запрашивают данные за последние 3-4 недели/месяца - а обновляются как раз в основном данные за 3-4 последних месяца. Да, для этих таблиц нужно смотреть на autovacuum, конечно, а не всякие там CLUSTER и т.п.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта