EXPLODE

将一行数据转为多行的UDTF。

注意事项

  • 如果参数是array<T>类型,则将列中存储的ARRAY转为多行。

  • 如果参数是map<K, V>类型,则将列中存储的MAP的每个Key-Value对转换为包含两列的行,其中一列存储Key,另一列存储Value。

  • 如果表中存在NULL数据,不会单独返回。

使用限制

  • 在一个select中只能出现一个explode函数,不可以出现表的其他列。

  • 不可以与group bycluster bydistribute bysort by一起使用。

命令格式

explode (<var>)

参数说明

var:必填。array<T>类型或map<K, V>类型。

返回值说明

返回转换后的行。

使用示例

  • 示例1:例如表t_table_map的字段为c1 bigint, t_map map<string,bigint>,包含数据如下:

      +------------+-------+
    | c1         | t_map |
    +------------+-------+
    | 1000       | {k11:86, k21:15} |
    | 1001       | {k12:97, k22:2} |
    | 1002       | {k13:99, k23:1} |
    +------------+-------+

    命令示例如下。

    select explode(t_map) from t_table_map;
    --返回结果如下。
    +-----+------------+
    | key | value      |
    +-----+------------+
    | k11 | 86         |
    | k21 | 15         |
    | k12 | 97         |
    | k22 | 2          |
    | k13 | 99         |
    | k23 | 1          |
    +-----+------------+
  • 示例2:返回结果中不包含单独的NULL行数据。

    --创建表
    create table explod_array (arr array<string>);
    --插入数据
    insert into table explod_array values (array('1','2','3',null,'agb')),
                                          (array('1','2','3',null,'ag')),
                                          (null);
    --查询数据
    select * from explod_array;
    --返回:
    +------------+
    | arr        |
    +------------+
    | ["1","2","3",null,"agb"] |
    | ["1","2","3",null,"ag"] |
    | NULL       |
    +------------+
    --展开数据
    select explode(arr) from explod_array;
    --返回结果里没有包括单独的NULL行数据
    +------------+
    | col        |
    +------------+
    | 1          |
    | 2          |
    | 3          |
    | NULL       |
    | agb        |
    | 1          |
    | 2          |
    | 3          |
    | NULL       |
    | ag         |
    +------------+
                        

相关函数

EXPLODE函数属于复杂类型函数,更多对复杂类型数据(例如ARRAY、MAP、STRUCT、JSON数据)的处理函数请参见复杂类型函数