Комбинатор If можно применять к агрегатной функции any,
чтобы выбрать первый элемент из указанного столбца,
соответствующий заданному условию.
В этом примере мы создадим таблицу для хранения данных о продажах с флагами успешности
и будем использовать anyIf, чтобы выбрать первые transaction_id со значением
выше и ниже 200.
Сначала создадим таблицу и вставим в неё данные:
CREATE TABLE sales(
transaction_id UInt32,
amount Decimal(10,2),
is_successful UInt8
)
ENGINE = MergeTree()
ORDER BY tuple();
INSERT INTO sales VALUES
(1, 100.00, 1),
(2, 150.00, 1),
(3, 155.00, 0),
(4, 300.00, 1),
(5, 250.50, 0),
(6, 175.25, 1);
SELECT
anyIf(transaction_id, amount < 200) AS tid_lt_200,
anyIf(transaction_id, amount > 200) AS tid_gt_200
FROM sales;
┌─tid_lt_200─┬─tid_gt_200─┐
│ 1 │ 4 │
└────────────┴────────────┘
Последнее изменение 10 июня 2026 г.