使用输入的两个字段分别作为Key和Value来构造Map,以第一个字段作为Map的Key,以第二个字段作为Map的Value。如果key为NULL,则被忽略。如果Key的取值有重复,则会随机只保留其中的一个。
注意事项
升级到MaxCompute 2.0后,产品扩展了部分函数。如果您用到的函数涉及新数据类型(TINYINT、SMALLINT、INT、FLOAT、VARCHAR、TIMESTAMP或BINARY),在使用扩展函数时,需要执行如下语句开启新数据类型开关:
在同一条SQL语句中同时使用多个聚合函数时,如果项目资源不足,会出现内存溢出问题,请您根据实际业务情况优化SQL或购买计算资源。
命令格式
map<K, V> map_agg(K a, V b);
参数说明
a:输入字段,将作为Map的Key。
b:输入字段,将作为Map的value。
返回值说明
返回构造的Map。
示例
select map_agg(a, b) from
values (1L, 'apple'), (2L, 'hi'), (null, 'good'), (1L, 'pie') t(a, b);
返回结果如下。
+------------------------+
| _c0 |
+------------------------+
| {"2":"hi","1":"apple"} |
+------------------------+
相关函数
MAP_AGG函数属于聚合函数,更多将多条输入记录进行求平均值、参数聚合的相关函数请参见聚合函数。