對輸入Map進行Union並對同一個Key的Value進行求和操作構造輸出Map,如果某一個Key對應的Value為NULL,則將其轉換為0。
注意事項
升級到MaxCompute 2.0後,產品擴充了部分函數。如果您用到的函數涉及新資料類型(TINYINT、SMALLINT、INT、FLOAT、VARCHAR、TIMESTAMP或BINARY),在使用擴充函數時,需要執行如下語句開啟新資料類型開關:
在同一條SQL語句中同時使用多個彙總函式時,如果專案資源不足,會出現記憶體溢出問題,請您根據實際業務情況最佳化SQL或購買計算資源。
命令格式
map<K, V> map_union_sum(map<K, V> input);
參數說明
input:輸入Map。
說明
輸入Map的Value的類型必須是數實值型別,例如BIGINT、INT、SMALLINT、TINYINT、FLOAT、DOUBLE、DECIMAL。
傳回值說明
返回構造的Map。
說明
輸出Map的Value類型是BIGINT、DOUBLE、DECIMAL。
樣本
select map_union_sum(a) from values
(map('hi', 2L, 'apple', 3L, 'pie', 1L)), (map('apple', null, 'hi', 4L)), (null) t(a);
返回結果如下。
+----------------------------+
| _c0 |
+----------------------------+
| {"apple":3,"hi":6,"pie":1} |
+----------------------------+
相關函數
MAP_UNION_SUM函數屬於彙總函式,更多將多條輸入記錄進行求平均值、參數彙總的相關函數請參見彙總函式。