Лямбда-выражения#
Лямбда-выражения - это анонимные функции, которые могут быть переданы в качестве аргументов некоторым функциям SQL более высокого порядка.
Используйте ->
для обозначения лямбда-выражения:
x -> x + 1
(x, y) -> x + y
x -> regexp_like(x, 'a+')
x -> x[1] / x[2]
x -> IF(x > 0, x, -x)
x -> COALESCE(x, 0)
x -> CAST(x AS JSON)
x -> x + TRY(1 / 0)
Ограничения#
Большинство выражений SQL можно использовать в теле лямбда-выражений.
Исключения:
Не поддерживаются подзапросы:
x -> 2 + (SELECT 3)
Не поддерживаются агрегации:
x -> max(y)
Примеры#
Возводит элементы массива в квадрат с помощью transform()
:
SELECT numbers,
transform(numbers, n -> n * n) as squared_numbers
FROM (
VALUES
(ARRAY[1, 2]),
(ARRAY[3, 4]),
(ARRAY[5, 6, 7])
) AS t(numbers);
numbers | squared_numbers
-----------+-----------------
[1, 2] | [1, 4]
[3, 4] | [9, 16]
[5, 6, 7] | [25, 36, 49]
(3 rows)
Преобразует элементы массива в строки:
SELECT transform(prices, n -> TRY_CAST(n AS VARCHAR) || '$') as price_tags
FROM (
VALUES
(ARRAY[100, 200]),
(ARRAY[30, 4])
) AS t(prices);
price_tags
--------------
[100$, 200$]
[30$, 4$]
(2 rows)
В лямбда-выражении могут быть использованы несколько колонок. Пример вычисления значений линейной функции f(x) = ax + b
с помощью transform()
:
SELECT xvalues,
a,
b,
transform(xvalues, x -> a * x + b) as linear_function_values
FROM (
VALUES
(ARRAY[1, 2], 10, 5),
(ARRAY[3, 4], 4, 2)
) AS t(xvalues, a, b);
xvalues | a | b | linear_function_values
---------+----+---+------------------------
[1, 2] | 10 | 5 | [15, 25]
[3, 4] | 4 | 2 | [14, 18]
(2 rows)
Находит записи, в которых колонка numbers
содержит хотя бы одно значение больше 100
, с помощью any_match()
:
SELECT numbers
FROM (
VALUES
(ARRAY[1,NULL,3]),
(ARRAY[10,20,30]),
(ARRAY[100,200,300])
) AS t(numbers)
WHERE any_match(numbers, n -> COALESCE(n, 0) > 100);
-- [100, 200, 300]
Преобразует первый символ первого слова строки к верхнему регистру с помощью regexp_replace()
:
SELECT regexp_replace('once upon a time ...', '^(\w)(\w*)(\s+.*)$',x -> upper(x[1]) || x[2] || x[3]);
-- Once upon a time ...
Вычисление суммы всех элементов столбца с помощью reduce_agg()
:
SELECT reduce_agg(value, 0, (a, b) -> a + b, (a, b) -> a + b) sum_values
FROM (
VALUES (1), (2), (3), (4), (5)
) AS t(value);
-- 15