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

Добрый день, ребят, подскажите пожалуйста, как можно решить следующую проблему,


есть таблица с 8 колонками
hash_slice(SHA-256),
event_type(String),
news_id(Uint64),
stream_uuid(UUID),
money(Float64),
money_with_commission(Float64),
created_at(Datetime),
sign Int8
Движок таблицы CollapisngMergeTree(sign)
ORDER BY в таблице (hash_slice, event_type)
Нужно сделать аггрегацию этой таблицы, по toStartOfHour(created_at) и hash_slice
Для этих целей был выбран движок SummingMergeTree((money, money_with_commission))
Для 2-х типов событий все колонки кроме money и money_with_commission заполнены, а вот для третьего заполены лишь hash_slice, event_type, money, money_with_commission. А другие равны Null, CH при агрегации в каких то случаях, видимо когда последнее событие с нулами, при агрегации трет поля news_id и stream_uuid и в агрегационной статистике они равны NULL, а иногда нет, как сделать так, чтобы при агрегации нулы игнорировались если в событиях выше или ниже есть данные в колонках stream_uuid или news_id и при агрегации эти колонки всегда были заполнены? Есть идеи?

6 ответов

9 просмотров

sign для CollapsingMergeTree не может быть UInt8 сделайте Int8

Stanislav-Chechun Автор вопроса
Stanislav Chechun
Я препутал, да, там Int8, спасибо))

уберите для money и money_with_comission Float64 замените на Decimal64 и уберите Nullable пусть будет просто 0 вторая таблица из первой заполняется через Materialized VIEW?

Stanislav-Chechun Автор вопроса
Slach [altinity]
уберите для money и money_with_comission Float64 з...

Спасибо)) А почему именно Decimal64?

Stanislav Chechun
Спасибо)) А почему именно Decimal64?

при суммировании будет не будет ошибок округления из Float float для денег не предназначен

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
function LoadMemoryFromInet2( f:TMemoryStream; const url:string; var e:string ):Boolean; var http:TIdHttp; LHandler: TIdSSLIOHandlerSocketOpenSSL;begin Result := fals...
Александр Смоляков
1
Я вот подумал. SSE выполняет операции максимум с 64-битной точностью. А FPU - всегда с 80-битной. Разве не должно быть FPU точнее тогда?
The Bird of Hermes
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
как быть с принтером? такой подход прокатит?
zamtmn
12
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Карта сайта