JSON 値を変更する JSON 関数
このドキュメントでは、JSON 値を変更する JSON関数について説明します。
JSON_APPEND()
JSON_ARRAY_APPEND()
JSON_ARRAY_APPEND(json_array, path, value [,path, value] ...)関数は、JSON ドキュメント内の指定された配列の末尾に指定されたpathに値を追加し、結果を返します。
この関数は引数をペアで受け取ります。各ペアはpathとvalueです。
例:
次の例では、JSON ドキュメントのルートである配列に項目を追加します。
SELECT JSON_ARRAY_APPEND('["Car", "Boat", "Train"]', '$', "Airplane") AS "Transport options";
+--------------------------------------+
| Transport options                    |
+--------------------------------------+
| ["Car", "Boat", "Train", "Airplane"] |
+--------------------------------------+
1 row in set (0.00 sec)
次の例では、指定されたパスの配列に項目を追加します。
SELECT JSON_ARRAY_APPEND('{"transport_options": ["Car", "Boat", "Train"]}', '$.transport_options', "Airplane") AS "Transport options";
+-------------------------------------------------------------+
| Transport options                                           |
+-------------------------------------------------------------+
| {"transport_options": ["Car", "Boat", "Train", "Airplane"]} |
+-------------------------------------------------------------+
1 row in set (0.00 sec)
JSON_ARRAY_INSERT()
JSON_ARRAY_INSERT(json_array, path, value [,path, value] ...)関数は、 pathのjson_arrayの指定された位置にvalue挿入し、結果を返します。
この関数は引数をペアで受け取ります。各ペアはpathとvalueです。
例:
次の例では、配列のインデックス 0 の位置に値を挿入します。
SELECT JSON_ARRAY_INSERT('["Car", "Boat", "Train"]', '$[0]', "Airplane") AS "Transport options";
+--------------------------------------+
| Transport options                    |
+--------------------------------------+
| ["Airplane", "Car", "Boat", "Train"] |
+--------------------------------------+
1 row in set (0.01 sec)
次の例では、配列のインデックス 1 の位置に値を挿入します。
SELECT JSON_ARRAY_INSERT('["Car", "Boat", "Train"]', '$[1]', "Airplane") AS "Transport options";
+--------------------------------------+
| Transport options                    |
+--------------------------------------+
| ["Car", "Airplane", "Boat", "Train"] |
+--------------------------------------+
1 row in set (0.00 sec)
JSON_INSERT()
JSON_INSERT(json_doc, path, value [,path, value] ...)関数は、JSON ドキュメントに 1 つ以上の値を挿入し、結果を返します。
この関数は引数をペアで受け取ります。各ペアはpathとvalueです。
SELECT JSON_INSERT(
    '{"language": ["Go", "Rust", "C++"]}',
    '$.architecture', 'riscv',
    '$.os', JSON_ARRAY("linux","freebsd")
) AS "Demo";
+------------------------------------------------------------------------------------------+
| Demo                                                                                     |
+------------------------------------------------------------------------------------------+
| {"architecture": "riscv", "language": ["Go", "Rust", "C++"], "os": ["linux", "freebsd"]} |
+------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
この関数は既存の属性の値を上書きしないことに注意してください。たとえば、次のステートメントは"a"属性を上書きするように見えますが、実際には上書きされません。
SELECT JSON_INSERT('{"a": 61, "b": 62}', '$.a', 41, '$.c', 63);
+---------------------------------------------------------+
| JSON_INSERT('{"a": 61, "b": 62}', '$.a', 41, '$.c', 63) |
+---------------------------------------------------------+
| {"a": 61, "b": 62, "c": 63}                             |
+---------------------------------------------------------+
1 row in set (0.00 sec)
JSON_MERGE_PATCH()
JSON_MERGE_PATCH(json_doc, json_doc [,json_doc] ...)関数は、重複するキーの値を保持せずに、2 つ以上の JSON ドキュメントを 1 つの JSON ドキュメントにマージします。重複するキーを持つjson_docの引数の場合、後で指定されたjson_doc引数の値のみがマージされた結果に保持されます。
例:
次の例では、値aが引数 2 によって上書きされ、マージされた結果にc新しい属性として追加されていることがわかります。
SELECT JSON_MERGE_PATCH(
    '{"a": 1, "b": 2}',
    '{"a": 100}',
    '{"c": 300}'
);
+-----------------------------------------------------------------+
| JSON_MERGE_PATCH('{"a": 1, "b": 2}','{"a": 100}', '{"c": 300}') |
+-----------------------------------------------------------------+
| {"a": 100, "b": 2, "c": 300}                                    |
+-----------------------------------------------------------------+
1 row in set (0.00 sec)
JSON_MERGE_PRESERVE()
JSON_MERGE_PRESERVE(json_doc, json_doc [,json_doc] ...)関数は、各キーに関連付けられたすべての値を保持しながら 2 つ以上の JSON ドキュメントをマージし、マージされた結果を返します。
例:
次の例では、引数 2 の値がaに追加され、 c新しい属性として追加されていることがわかります。
SELECT JSON_MERGE_PRESERVE('{"a": 1, "b": 2}','{"a": 100}', '{"c": 300}');
+--------------------------------------------------------------------+
| JSON_MERGE_PRESERVE('{"a": 1, "b": 2}','{"a": 100}', '{"c": 300}') |
+--------------------------------------------------------------------+
| {"a": [1, 100], "b": 2, "c": 300}                                  |
+--------------------------------------------------------------------+
1 row in set (0.00 sec)
JSON_MERGE()
JSON_MERGE_PRESERVE()の非推奨のエイリアス。
JSON_REMOVE()
JSON_REMOVE(json_doc, path [,path] ...)関数は、JSON ドキュメントから指定されたpathのデータを削除し、結果を返します。
例:
この例では、JSON ドキュメントからb属性を削除します。
SELECT JSON_REMOVE('{"a": 61, "b": 62, "c": 63}','$.b');
+--------------------------------------------------+
| JSON_REMOVE('{"a": 61, "b": 62, "c": 63}','$.b') |
+--------------------------------------------------+
| {"a": 61, "c": 63}                               |
+--------------------------------------------------+
1 row in set (0.00 sec)
この例では、JSON ドキュメントからb属性とc属性を削除します。
SELECT JSON_REMOVE('{"a": 61, "b": 62, "c": 63}','$.b','$.c');
+--------------------------------------------------------+
| JSON_REMOVE('{"a": 61, "b": 62, "c": 63}','$.b','$.c') |
+--------------------------------------------------------+
| {"a": 61}                                              |
+--------------------------------------------------------+
1 row in set (0.00 sec)
JSON_REPLACE()
JSON_REPLACE(json_doc, path, value [, path, value] ...)関数は、JSON ドキュメントの指定されたパス内の値を置き換え、結果を返します。指定されたパスが存在しない場合は、パスに対応する値は結果に追加されません。
この関数は引数をペアで受け取ります。各ペアはpathとvalueです。
例:
次の例では、 $.bの値を62から42に変更します。
SELECT JSON_REPLACE('{"a": 41, "b": 62}','$.b',42);
+---------------------------------------------+
| JSON_REPLACE('{"a": 41, "b": 62}','$.b',42) |
+---------------------------------------------+
| {"a": 41, "b": 42}                          |
+---------------------------------------------+
1 row in set (0.00 sec)
次の例では、 $.bの値を62から42に変更できます。さらに、このステートメントは$.cの値を43に置き換えようとしますが、 $.cパスが{"a": 41, "b": 62}に存在しないため機能しません。
SELECT JSON_REPLACE('{"a": 41, "b": 62}','$.b',42,'$.c',43);
+------------------------------------------------------+
| JSON_REPLACE('{"a": 41, "b": 62}','$.b',42,'$.c',43) |
+------------------------------------------------------+
| {"a": 41, "b": 42}                                   |
+------------------------------------------------------+
1 row in set (0.00 sec)
JSON_SET()
JSON_SET(json_doc, path, value [,path, value] ...)関数は、JSON ドキュメントにデータを挿入または更新し、結果を返します。
この関数は引数をペアで受け取ります。各ペアはpathとvalueです。
例:
次の例では、 $.version 1.1から1.2に更新できます。
SELECT JSON_SET('{"version": 1.1, "name": "example"}','$.version',1.2);
+-----------------------------------------------------------------+
| JSON_SET('{"version": 1.1, "name": "example"}','$.version',1.2) |
+-----------------------------------------------------------------+
| {"name": "example", "version": 1.2}                             |
+-----------------------------------------------------------------+
1 row in set (0.00 sec)
次の例では、 $.versionを1.1から1.2に更新できます。また、以前は存在しなかった$.branchをmainに更新できます。
SELECT JSON_SET('{"version": 1.1, "name": "example"}','$.version',1.2,'$.branch', "main");
+------------------------------------------------------------------------------------+
| JSON_SET('{"version": 1.1, "name": "example"}','$.version',1.2,'$.branch', "main") |
+------------------------------------------------------------------------------------+
| {"branch": "main", "name": "example", "version": 1.2}                              |
+------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
JSON_UNQUOTE()
JSON_UNQUOTE(json)関数は JSON 値を引用符で囲まず、結果を文字列として返します。これはJSON_QUOTE()関数の逆です。
例:
この例では、 "foo"引用符で囲まれずにfooになります。
SELECT JSON_UNQUOTE('"foo"');
+-----------------------+
| JSON_UNQUOTE('"foo"') |
+-----------------------+
| foo                   |
+-----------------------+
1 row in set (0.00 sec)
この関数は、 JSON_EXTRACT()と一緒に使用されることが多いです。次の例では、最初の例で引用符付きの JSON 値を抽出し、2 つの関数を一緒に使用して 2 番目の例で値の引用符を解除できます。 JSON_UNQUOTE(JSON_EXTRACT(...))代わりに->>演算子を使用できることに注意してください。
SELECT JSON_EXTRACT('{"database": "TiDB"}', '$.database');
+----------------------------------------------------+
| JSON_EXTRACT('{"database": "TiDB"}', '$.database') |
+----------------------------------------------------+
| "TiDB"                                             |
+----------------------------------------------------+
1 row in set (0.00 sec)
SELECT JSON_UNQUOTE(JSON_EXTRACT('{"database": "TiDB"}', '$.database'));
+------------------------------------------------------------------+
| JSON_UNQUOTE(JSON_EXTRACT('{"database": "TiDB"}', '$.database')) |
+------------------------------------------------------------------+
| TiDB                                                             |
+------------------------------------------------------------------+
1 row in set (0.00 sec)