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

Никогда не работал с массивами в КХ, пните в нужном

направлении, пожалуйста.

CREATE TABLE TestTable
(
id Int32
, params Nested(
name LowCardinality(String)
, value String
)
)
ENGINE = Memory()
;

INSERT INTO TestTable(id, params.name, params.value)
VALUES (1, ['param1', 'param2'], ['val1', 'val2']), (2, ['param1', 'param2'], ['val1', 'val3']), (3, ['param1', 'param2', 'param3'], ['val1', 'val2', 'val4']), (4, ['param1', 'param2'], ['val1', 'val3'])
;

Как с учётом такой структуры выбрать, например, айдишники записей, у которых param1=val1 и param2=val2 (в данном примере 1 и 3)?
Или выбрать айдишники, набор параметров и значений которых не уникален (в данном примере 2 и 4)?

6 ответов

12 просмотров

WHERE params.name='param1' AND params.value='val1' ?

Alexey-Sokolov Автор вопроса
Slach [altinity]
WHERE params.name='param1' AND params.value='val1'...

Это для одного параметра, а для нескольких? В лоб у меня получился вот такой монстр: select id from TestTable array join params where (params.name, params.value) in (('param1', 'val1'), ('params2', 'val2')) group by id having count() > 1 Второй пример я сделал так: select (params.name, params.value) as p , groupArray(id) from TestTable group by p having uniq(id) > 0 Но мне оба решения не нравятся, наверняка это можно сделать проще и быстрее.

SELECT groupArray(arraySort((x) -> x.1, arrayZip(params.name,params.value))) AS uniq_params, count() AS ids_count FROM TestTable GROUP BY uniq_params HAVING ids_count > 1 попробуйте почитать

Alexey-Sokolov Автор вопроса
Slach [altinity]
SELECT groupArray(arraySort((x) -> x.1, arrayZip(p...

groupArray - это очепятка и там должен быть arrayDistinct?

Alexey Sokolov
Это для одного параметра, а для нескольких? В лоб...

Первое можно вот так, например where arrayElement(params.value, indexOf(params.name, 'param1')) = 'val1'

Alexey-Sokolov Автор вопроса
Andrey Nikulin
Первое можно вот так, например where arrayElement(...

Спасибо, попробую. Я ещё вот такой вариант придумал: where hasAll(arrayZip(param.name, param.value), [('param1', 'val1'), ('param2', 'val2')]) = 1

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта