Группировка с условием на всю группу | GROUP BY HAVING

Версия 3.11 от Alexandr Fokin на 2023/02/02 13:17


SELECT
    person_id
FROM MyTable
GROUP BY person_id
HAVING 3 = (
   MAX(CASE pet WHEN 'dog' THEN 1 ELSE 0 END)
+   MAX(CASE pet WHEN 'cat' THEN 1 ELSE 0 END)
+   MAX(CASE pet WHEN 'tiger ' THEN 1 ELSE 0 END)
)

С помощью CASE-WHEN и MAX можно выбрать только те группы, в которых есть указанное значение(я). (Хотя бы один раз)

Group by having at least one of each item
https://stackoverflow.com/questions/32122777/group-by-having-at-least-one-of-each-item

Теги:
Создал(а) Alexandr Fokin 2021/10/25 11:24