メインコンテンツまでスキップ

EXPLODE_JSON_ARRAY_STRING

説明

explode_json_array_stringテーブル関数はJSON配列を受け取ります。その実装ロジックは、JSON配列をarray型に変換してからexplode関数を呼び出して処理することです。この動作はexplode(cast(<json_array> as Array<STRING>))と同等です。 LATERAL VIEWと組み合わせて使用する必要があります。

構文

EXPLODE_JSON_ARRAY_STRING(<json>)

パラメータ

  • <json> JSON型、内容は配列である必要があります。

戻り値

  • <json> 内のすべての要素で構成される単一列、複数行の結果を返します。列の型は Nullable<STRING> です。
  • <json> が NULL または空の配列(要素数が 0)の場合、0 行が返されます。
  • JSON 配列内の要素が STRING 型でない場合、関数はそれらを STRING に変換しようとします。STRING への変換が失敗した場合、その要素は NULL に変換されます。型変換規則については、JSON Type Conversion を参照してください。

  1. データの準備

    create table example(
    k1 int
    ) properties(
    "replication_num" = "1"
    );

    insert into example values(1);
  2. 通常のパラメータ

    select * from example lateral view explode_json_array_string('[4, "5", "abc", 5.23, null]') t2 as c;
    +------+------+
    | k1 | c |
    +------+------+
    | 1 | 4 |
    | 1 | 5 |
    | 1 | abc |
    | 1 | 5.23 |
    | 1 | NULL |
    +------+------+
  3. 空の配列

    select * from example lateral view explode_json_array_string('[]') t2 as c;
    Empty set (0.03 sec)
  4. NULLパラメータ

    select * from example lateral view explode_json_array_string(NULL) t2 as c;
    Empty set (0.03 sec)
  5. 非配列パラメータ

    select * from example lateral view explode_json_array_string('{}') t2 as c;
    Empty set (0.03 sec)