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

Есть табличка: CREATE TABLE users ( user_id UInt64,

property1 String,
custom_properties Nested(k String, v String)
) Engine=MergeTree ORDER BY (user_id);

Достать кастомные поля я могу таким способом:
SELECT
user_id,
property1,
custom_properties.v[indexOf(custom_properties.k, 'color')],
custom_properties.v[indexOf(custom_properties.k, 'size')],
FROM test.nested

Выносим кастомные поля в отдельную табличку, чтобы легко можно было их обновлять:
CREATE TABLE user_properties (
user_id UInt64,
k String,
v String
) Engine=ReplacingMergeTree ORDER BY (user_id, k);


Написал такой запрос:

SELECT user_id, property1, vals[indexOf(keys, 'color')], vals[indexOf(keys, 'size')]
FROM users
JOIN (
SELECT user_id, groupArray(k) as keys, groupArray(v) as vals
FROM user_properties
GROUP BY user_id
) using (user_id)

всё вроде ок, одна проблема, что в документации написано:
"groupArray добавляет значения в любом (недетерминированном) порядке"

Есть какие-то детерминированные варианты?

2 ответов

9 просмотров

В некоторых случаях, вы всё же можете рассчитывать на порядок выполнения запроса. Это — случаи, когда SELECT идёт из подзапроса, в котором используется ORDER BY.

SELECT user_id, property1, vals[indexOf(keys, 'color')], vals[indexOf(keys, 'size')] FROM users JOIN ( SELECT user_id, groupArray(k) as keys, groupArray(v) as vals FROM (SELECT user_id, k, v FROM user_properties order by user_id, k) GROUP BY user_id ) using (user_id)

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

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

Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
2
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
у меня программа тысяч на 10 строк. Там в основном моя собственная логика. А по содержанию она просто работает с файловой системой (мастер для бэкапов) и таблицей с данными о ...
Дмитрий Завгородний
5
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Карта сайта