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

Подскажте пожалуйста. Я для каждой строки хочу посчитать агрегационную функцию для

строк с тем же первичным ключем.

Например
pk, attr
1, a
1, b
2, c

select pk, attr, accomulate(groupArray, attr) from tbl
1, a, [a, b]
1, b, [a, b]
2, c, [c]

Что-то похожее на lateral join и runningAccumulate
только ищущая по всем блокам, а не по текущему.
Строки с одним PK могут быть в разных блоках.

Можно такое сделать?

13 ответов

20 просмотров

GROUP BY не ?

Mikhail-Kuzmin Автор вопроса
Константин
GROUP BY не ?

не тогда было бы 1, [a, b] 2, [c] а не 1, a, [a, b] 1, b, [a, b] 2, c, [c]

select pk, attr, attrarr from ( select pk, groupArray(attr) attrarr from ( select 1 as pk, 'a' as attr UNION ALL select 1, 'b' UNION ALL select 2, 'c' ) group by pk ) array join attrarr as attr ; ┌─pk─┬─attr─┬─attrarr───┐ │ 1 │ a │ ['a','b'] │ │ 1 │ b │ ['a','b'] │ │ 2 │ c │ ['c'] │ └────┴──────┴───────────┘

Mikhail-Kuzmin Автор вопроса
【D】【J】
select pk, attr, attrarr from ( select pk, group...

я намерено написал: «Я для каждой строки хочу посчитать агрегационную функцию для строк с тем же первичным ключем.» Я хочу исходную таблицу фильтровать по pk и не pk. Т.е. я хочу отфильтровать табличку и прицепить к строкам ВСЕ строки с тем же pk. В том числе не попавшие под условие.

Mikhail Kuzmin
я намерено написал: «Я для каждой строки хочу пос...

их придется фильтровать в arrayFilter уже либо в самом конце

Mikhail-Kuzmin Автор вопроса
【D】【J】
их придется фильтровать в arrayFilter уже либо в с...

ну вот в том то и проблема, что их много и я хочу сначала отфильтровать и потом подцепить а не выбрать очень-много-строк, сгруппировать и фильтровать.

Mikhail Kuzmin
я намерено написал: «Я для каждой строки хочу пос...

select pk, attr, attrarr from ( select pk, groupArray(attr) attrarr from ( select 1 as pk, 'a' as attr UNION ALL select 1, 'b' UNION ALL select 2, 'c' ) group by pk ) array join attrarr as attr where attr!='b' ; ┌─pk─┬─attr─┬─attrarr───┐ │ 1 │ a │ ['a','b'] │ │ 2 │ c │ ['c'] │ └────┴──────┴───────────┘

Mikhail-Kuzmin Автор вопроса
【D】【J】
select pk, attr, attrarr from ( select pk, group...

where attr!='b' - как раз снаружи, а нужно внутри

Mikhail Kuzmin
ну вот в том то и проблема, что их много и я хочу ...

тогда подзапросом... дайте сгенерированный селект из numbers с примерами фильтров. а то сложно угадывать

Mikhail Kuzmin
where attr!='b' - как раз снаружи, а нужно внутри

ну вы хотите при этом чтобы в массиве 'b' остался и не фильтровался же?

Mikhail-Kuzmin Автор вопроса
【D】【J】
тогда подзапросом... дайте сгенерированный селект ...

Например pk, attr 1, a 1, b 2, a select pk, attr, accumulate(groupArray, attr) from tbl where attr = 'a'; 1, a, [a, b] 2, a, [a]

Mikhail Kuzmin
Например pk, attr 1, a 1, b 2, a select pk, attr,...

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

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

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

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