направлении, пожалуйста.
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)?
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 попробуйте почитать
groupArray - это очепятка и там должен быть arrayDistinct?
Первое можно вот так, например where arrayElement(params.value, indexOf(params.name, 'param1')) = 'val1'
Спасибо, попробую. Я ещё вот такой вариант придумал: where hasAll(arrayZip(param.name, param.value), [('param1', 'val1'), ('param2', 'val2')]) = 1
Обсуждают сегодня