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

Вечер добрый, есть таблица балансов в пг: id, balance, created_at, updated_at время

создания аккаунта и время когда обновился баланс
была мысль сделать RMT и последовательно инкрементом подливать сначала новые аккаунты, потом обновленные балансы.
Но понял, что при дневном партиционированнии по дате создания - не получится нормально оптимайзить за предыдущий день, тк апдейты могут быть по очень старым аккаунтам, как советуют тут
https://kb.altinity.com/altinity-kb-queries-and-syntax/altinity-kb-final-clause-speed/
Оптимайзить всю таблицу может быть со временем дорого, сейчас 10кк строк, но очень быстро растем

Хотел бы уточнить будет ли работать в целом такая схема и есть ли варианты по оптимизации?

8 ответов

9 просмотров

select * from table_name final prewhere id= X - в вашем кейсе без потерь ибо ид это праймари кей для реплейсинг табы. Партицирование тут мимо, но если хочется поделить - может помочь "бакетинг", т.е. по префиксу ид (если uuid) или ренжу / остатку от деления на N - зависит от типа ид короче

Matvey- Автор вопроса

А цель - получать текущий или на конец конкретного дня баланс? Если да, то неплохо подойдет AggregatingMergeTree.

Matvey- Автор вопроса
Vasilij Abrosimov
А цель - получать текущий или на конец конкретного...

Цель текущий всегда актуальный иметь = стейт из пг в кх

Matvey
Цель текущий всегда актуальный иметь = стейт из пг...

Тогда подойдет и RMT, только не надо партиционировать по периоду. Например по id%100. Тогда парты будут регулярно мержиться и оставаться небольшими.

Matvey- Автор вопроса
Vasilij Abrosimov
Тогда подойдет и RMT, только не надо партициониров...

а перфоманс джоинов на final сильно проседать будет?

Matvey
а перфоманс джоинов на final сильно проседать буде...

Да, может просесть весьма сильно, но зачем вам final? Дедуплицируйте в селекте. SELECT ... FROM rmt_table ORDER BY updated_at DESC LIMIT 1 BY id А клик пусть себе мержит в фоне.

Matvey- Автор вопроса

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
А дальше что?.. Записать в файл, потом в Код?.. И потом разбирать как-то?..
Хаскель Моисеевич Гопник
14
доброго времени. db, dw и прочие исполняются при трансляции или при выполнении программы?
lutayyy
10
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
например asm AT&T ... label: .string "hi" ... # not error lea label(%rip), %rax # error ( not compile ) mov %rip, %rax # not error mov (%rip), %rax из форумов прочитал чт...
Simple Sorcerer
6
Почему никто не подсказал, что можно объявить свои типы данных, в которых меньше полей, чем в отданном джейсоне, и добавлять их по необходимости?
Strange Rabbit
10
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Есть предложения, как подобное можно упростить?
Hemul GM
12
Карта сайта