map_concat
説明
入力されたマップの合併を返します。複数のマップに同じキーが存在する場合、この関数はこれらのマップの中で最後の値のみを保持します。これをLAST WINと呼びます。例えば、SELECT map_concat(map{1:3},map{1:'4'});
は {1:"4"}
を返します。
この関数はv3.1以降でサポートされています。
構文
ANY_MAP map_concat(any_map0, any_map1...)
パラメータ
any_mapN
: 合併したいマップの値。すべてのマップは共通の型を持つ必要があります。入力マップのデータ型が異なる場合、返される型は入力マップの共通のスーパータイプです。
戻り値
入力マップの共通のスーパータイプのMAPを返します。
例
mysql> SELECT map_concat(map('a',1, 'b',2), map('c',3));
+------------------------------------------+
| map_concat(map{'a':1,'b':2}, map{'c':3}) |
+------------------------------------------+
| {"c":3,"a":1,"b":2} |
+------------------------------------------+
mysql> select map_concat(map{1:3},map{'3.323':3});
+--------------------------------------+
| map_concat(map{1:3}, map{'3.323':3}) |
+--------------------------------------+
| {"3.323":3,"1":3} |
+--------------------------------------+
mysql> select map_concat(map{1:3},map{1:'4', 3:'5',null:null}, null);
+--------------------------------------------------------+
| map_concat(map{1:3}, map{1:'4',3:'5',NULL:NULL}, NULL) |
+--------------------------------------------------------+
| {null:null,1:"4",3:"5"} |
+--------------------------------------------------------+