メインコンテンツまでスキップ
バージョン: 26.x

ARRAY_MAP

array_map

説明

配列の要素にラムダ式を適用し、新しい配列を返します。この関数は配列内の各要素にラムダ式を適用し、対応する結果を返します。

構文

array_map(lambda, ARRAY<T> arr1, [ARRAY<T> arr2, ...])

パラメータ

  • lambda:変換ルールを定義するために使用されるlambda式
  • arr1, arr2, ...:ARRAY型、変換対象の配列。1つ以上の配列パラメータをサポート。

Tでサポートされる型:

  • 数値型:TINYINT、SMALLINT、INT、BIGINT、LARGEINT、FLOAT、DOUBLE、DECIMAL
  • 文字列型:CHAR、VARCHAR、STRING
  • 日付・時刻型:DATE、DATETIME、DATEV2、DATETIMEV2
  • Boolean型:BOOLEAN
  • IP型:IPV4、IPV6
  • 複合型:ARRAY、MAP、STRUCT

戻り値

戻り値の型:ARRAY

戻り値の意味:

  • 入力配列と同じ長さの新しい配列を返し、各位置には対応する要素にlambda式を適用した結果が含まれる

使用上の注意:

  • lambda式のパラメータ数は配列パラメータ数と一致する必要がある
  • 入力配列パラメータにNULLはサポートされない
  • 複数の配列パラメータがある場合、すべての配列の長さが同じである必要がある
  • Lambdaは任意のスカラー式を使用できるが、集約関数は使用できない
  • Lambda式は他の高階関数を呼び出すことができるが、戻り値の型は互換性がある必要がある
  • 配列要素のnull値について:null要素はlambda式に処理のために渡され、lambdaはnull値をチェックできる

クエリ例:

配列の各要素を二乗する:

SELECT array_map(x -> x * x, [1, 2, 3, 4, 5]);
+------------------------------------------+
| array_map(x -> x * x, [1, 2, 3, 4, 5]) |
+------------------------------------------+
| [1, 4, 9, 16, 25] |
+------------------------------------------+

浮動小数点数配列の各要素を丸めます:

SELECT array_map(x -> round(x), [1.1, 2.7, 3.3, 4.9, 5.5]);
+--------------------------------------------------+
| array_map(x -> round(x), [1.1, 2.7, 3.3, 4.9, 5.5]) |
+--------------------------------------------------+
| [1, 3, 3, 5, 6] |
+--------------------------------------------------+

文字列配列内の各要素の長さを計算する:

SELECT array_map(x -> length(x), ['a', 'bb', 'ccc', 'dddd', 'eeeee']);
+--------------------------------------------------+
| array_map(x -> length(x), ['a', 'bb', 'ccc', 'dddd', 'eeeee']) |
+--------------------------------------------------+
| [1, 2, 3, 4, 5] |
+--------------------------------------------------+

null値を含む配列を処理する:

SELECT array_map(x -> x is not null, [1, null, 3, null, 5]);
+--------------------------------------------------+
| array_map(x -> x is not null, [1, null, 3, null, 5]) |
+--------------------------------------------------+
| [1, 0, 1, 0, 1] |
+--------------------------------------------------+

NULLはarray_mapに適用できず、エラーが発生します:

mysql> SELECT array_map(x->x>2, NULL);
ERROR 1105 (HY000): errCode = 2, detailMessage = lambda argument must be array but is NULL

複数の配列パラメータの例、2つの配列から対応する要素を加算する場合:

SELECT array_map((x, y) -> x + y, [1, 2, 3, 4, 5], [10, 20, 30, 40, 50]);
+--------------------------------------------------+
| array_map((x, y) -> x + y, [1, 2, 3, 4, 5], [10, 20, 30, 40, 50]) |
+--------------------------------------------------+
| [11, 22, 33, 44, 55] |
+--------------------------------------------------+

ネストされた配列の処理、各サブ配列の長さを計算する:

SELECT array_map(x -> size(x), [[1,2],[3,4,5],[6],[7,8,9,10]]);
+--------------------------------------------------+
| array_map(x -> size(x), [[1,2],[3,4,5],[6],[7,8,9,10]]) |
+--------------------------------------------------+
| [2, 3, 1, 4] |
+--------------------------------------------------+

マップ型の処理、各マップからキー 'a' の値を抽出:

SELECT array_map(x -> x['a'], [{'a':1,'b':2}, {'a':3,'b':4}, {'a':5,'b':6}]);
+--------------------------------------------------+
| array_map(x -> x['a'], [{'a':1,'b':2}, {'a':3,'b':4}, {'a':5,'b':6}]) |
+--------------------------------------------------+
| [1, 3, 5] |
+--------------------------------------------------+

パラメータ数が間違っている場合のエラー:

SELECT array_map();
ERROR 1105 (HY000): errCode = 2, detailMessage = Can not found function 'array_map' which has 0 arity. Candidate functions are: [array_map(Expression, Expression...)]

lambda式のパラメータ数が配列パラメータ数と一致しない場合のエラー:

SELECT array_map(x -> x > 0, [1,2,3], [4,5,6], [7,8,9]);
ERROR 1105 (HY000): errCode = 2, detailMessage = lambda x -> (x > 0) arguments' size is not equal parameters' size

非配列型を渡した際のエラー:

SELECT array_map(x -> x * 2, 'not_an_array');
ERROR 1105 (HY000): errCode = 2, detailMessage = Can not find the compatibility function signature: array_map(Expression, VARCHAR(12))

キーワード

ARRAY, MAP, ARRAY_MAP