MULTIMAP_AGG

使用输入的两个字段分别作为KeyValue来构造Map,以第一个字段作为MapKey,将相同Key的所有第二个字段的值构造成一个数组来作为MapValue。如果keyNULL,则被忽略。

注意事项

  • 升级到MaxCompute 2.0后,产品扩展了部分函数。如果您用到的函数涉及新数据类型(TINYINT、SMALLINT、INT、FLOAT、VARCHAR、TIMESTAMPBINARY),在使用扩展函数时,需要执行相关语句开启新数据类型开关:

    • Session级别:在SQL语句前添加set odps.sql.type.system.odps2=true;,并与SQL语句一起提交执行。

    • Project级别:Project Owner根据需要对Project进行设置。命令如下。

      setproject odps.sql.type.system.odps2=true;

      设置生效需要等待10~15分钟。

      更多setproject的详细说明,请参见项目空间操作。关于开启Project级别数据类型的注意事项,请参见数据类型版本说明

  • 在同一条SQL语句中同时使用多个聚合函数时,如果项目资源不足,会出现内存溢出问题,请您根据实际业务情况优化SQL或购买计算资源。

命令格式

map<K, array<V>> multimap_agg(K a, V b);

参数说明

  • a:将作为MapKey。

  • b:具有相同Key的值将被放入同一个数组中,作为Mapvalue。

返回值说明

返回构造的Map。

示例

select multimap_agg(a, b) from
        values (1L, 'apple'), (2L, 'hi'), (null, 'good'), (1L, 'pie') t(a, b);

返回结果如下。

+----------------------------------+
| _c0                              |
+----------------------------------+
| {"2":["hi"],"1":["apple","pie"]} |
+----------------------------------+

相关函数

MULTIMAP_AGG函数属于聚合函数,更多相关聚合函数请参见聚合函数