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

Друзья! Что-то я застрял на какой-то банальщине. Не могу понять,

как в условии использовать имя столбца, а не преобразовывать в плоский массив и через номер элемента получать доступ к значению.

Таблица:
set flatten_nested = 0;
create table test_b (
d DateTime,
id UInt64,
n Nested (
level1_id UInt64,
level1_data Nested (
level2_id UInt64,
level2_data Nested (
level3_id UInt64,
level3_field1 String,
level3_field2 UInt8
)
)
)
) ENGINE MergeTree
ORDER BY (d, id);

Данные:

insert into test_b (d, id, n) values
(
'2020-01-01',
111,
([
(
123 , [
(
321, [
(431, 'sss', 1)
]
)
]
)
])
),
(
'2022-01-20',
222,
([
(
1, [
(
11, [
(221, 'первая строка', 1),
(222, 'вторая строка', 2)
]
),
(
5678, []
)
]
),
(
2, []
),
(
888, [
(
999, [
(0, 'третья строка', 3)
]
)
]
)
])
);

Отформатировал, чтобы было понятно, что записывается в такую структуру. В общем, дальше, допустим, хочу просуммировать последний столбец с использованием условия:

select arraySum(s -> if(s.2 != 'sss', s.3, 0), arrayFlatten(n.level1_data.level2_data)) as f
from test_b;

Здесь я преобразую в плоский массив структуру и через номер элемента получаю нужное. Но хотелось бы через имя поля добираться. Это вообще возможно?

1 ответов

17 просмотров

см. куда нибудь в сторону работы с map https://clickhouse.com/docs/en/sql-reference/functions/tuple-map-functions/

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Всем привет! Кто пользуется DevExpress, подскажите пожалуйста, реализован ли в TcxGrid в новых версиях поиск по датам как в Экселе (ну т.е. не просто список чекбоксов со значе...
A Z
4
Карта сайта