mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-12 09:22:05 +00:00
81 lines
4.4 KiB
Markdown
81 lines
4.4 KiB
Markdown
# Функции высшего порядка
|
||
|
||
## Оператор `->`, функция lambda(params, expr)
|
||
|
||
Позволяет описать лямбда-функцию для передачи в функцию высшего порядка. Слева от стрелочки стоит формальный параметр - произвольный идентификатор, или несколько формальных параметров - произвольные идентификаторы в кортеже. Справа от стрелочки стоит выражение, в котором могут использоваться эти формальные параметры, а также любые столбцы таблицы.
|
||
|
||
Примеры: `x -> 2 * x, str -> str != Referer.`
|
||
|
||
Функции высшего порядка, в качестве своего функционального аргумента могут принимать только лямбда-функции.
|
||
|
||
В функции высшего порядка может быть передана лямбда-функция, принимающая несколько аргументов. В этом случае, в функцию высшего порядка передаётся несколько массивов одинаковых длин, которым эти аргументы будут соответствовать.
|
||
|
||
Для всех функций кроме arrayMap, arrayFilter, первый аргумент (лямбда-функция) может отсутствовать. В этом случае, подразумевается тождественное отображение.
|
||
|
||
### arrayMap(func, arr1, ...)
|
||
Вернуть массив, полученный из исходного применением функции func к каждому элементу массива arr.
|
||
|
||
### arrayFilter(func, arr1, ...)
|
||
Вернуть массив, содержащий только те элементы массива arr1, для которых функция func возвращает не 0.
|
||
|
||
Примеры:
|
||
|
||
```sql
|
||
SELECT arrayFilter(x -> x LIKE '%World%', ['Hello', 'abc World']) AS res
|
||
```
|
||
|
||
```text
|
||
┌─res───────────┐
|
||
│ ['abc World'] │
|
||
└───────────────┘
|
||
```
|
||
|
||
```sql
|
||
SELECT
|
||
arrayFilter(
|
||
(i, x) -> x LIKE '%World%',
|
||
arrayEnumerate(arr),
|
||
['Hello', 'abc World'] AS arr)
|
||
AS res
|
||
```
|
||
|
||
```text
|
||
┌─res─┐
|
||
│ [2] │
|
||
└─────┘
|
||
```
|
||
|
||
### arrayCount(\[func,\] arr1, ...)
|
||
Вернуть количество элементов массива arr, для которых функция func возвращает не 0. Если func не указана - вернуть количество ненулевых элементов массива.
|
||
|
||
### arrayExists(\[func,\] arr1, ...)
|
||
Вернуть 1, если существует хотя бы один элемент массива arr, для которого функция func возвращает не 0. Иначе вернуть 0.
|
||
|
||
### arrayAll(\[func,\] arr1, ...)
|
||
Вернуть 1, если для всех элементов массива arr, функция func возвращает не 0. Иначе вернуть 0.
|
||
|
||
### arraySum(\[func,\] arr1, ...)
|
||
Вернуть сумму значений функции func. Если функция не указана - просто вернуть сумму элементов массива.
|
||
|
||
### arrayFirst(func, arr1, ...)
|
||
Вернуть первый элемент массива arr1, для которого функция func возвращает не 0.
|
||
|
||
### arrayFirstIndex(func, arr1, ...)
|
||
Вернуть индекс первого элемента массива arr1, для которого функция func возвращает не 0.
|
||
|
||
### arrayCumSum(\[func,\] arr1, ...)
|
||
|
||
Возвращает массив из частичных сумм элементов исходного массива (сумма с накоплением). Если указана функция `func`, то значения элементов массива преобразуются этой функцией перед суммированием.
|
||
|
||
Пример:
|
||
|
||
```sql
|
||
SELECT arrayCumSum([1, 1, 1, 1]) AS res
|
||
```
|
||
|
||
```text
|
||
┌─res──────────┐
|
||
│ [1, 2, 3, 4] │
|
||
└──────────────┘
|
||
```
|