使用輸入的兩個欄位分別作為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函數屬於彙總函式,更多將多條輸入記錄進行求平均值、參數彙總的相關函數請參見彙總函式。