У меня есть следующие данные в моей базе данных PostgreSQL 11 count_tbl
(Windows 10 x64 machine).
grp id value
1 1 19.7
1 2 19.7
1 3 19.7
1 4 19.7
1 5 19.7
1 6 19.7
1 7 18.8
1 8 18.8
1 9 18.8
1 10 18.8
1 11 18.8
1 12 18.8
2 1 18.6
2 2 18.6
2 3 18.6
2 4 18.6
2 5 18.6
2 6 0.0
2 7 0.0
2 8 0.0
2 9 21.4
2 10 21.4
2 11 0.0
2 12 0.0
Следующий запрос для каждой группы (grp
) находит Наиболее частое значение:
Select Distinct on (grp)
grp,
case
when freq > 1
then value
else 0.0
end as freq_val
From
(
Select
grp,
value,
count(id) as freq
From count_tbl
Group by grp, value
Order by grp
) s1
Order by grp, freq desc, value desc;
Вывод вышеуказанного запроса:
grp freq_val
1 19.7
2 18.6
Теперь я хотел бы связать наиболее частое значение с соответствующими идентификаторами (например, для grp = 1
, наиболее частое значение 19.7
имеет идентификаторы 1, 2, 3, 4, 5, 6), скажем, как integer array
. Мой ожидаемый результат:
grp freq_val ids
1 19.7 {1,2,3,4,5,6}
2 18.6 {1,2,3,4,5}
Кто-то хочет поразмышлять над этим или предложить, как этого можно достичь?