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 ответов

3 просмотра

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

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

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

Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
36
Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
47
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
20
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
А чем вам питонисты не угодили?😂
.
79
у меня вопрос на счет .global <name> для чего это нужно если я пишу на ассемблере? только для того что бы сделать это видимым для линкера? вот что написано в докумментации GA...
Simple Sorcerer
1
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
У меня вот только только был затык при изучении одной темы. Я настолько привык к джс, что мозг с трудом признал таки, что f и \x -> f x - это равные функции. Потому что в д...
xfides Barabanov
7
Карта сайта