JSON_SET
説明
json_set関数はJSONにデータを挿入または更新し、結果を返します。
構文
JSON_SET (<json_str>, <path>, <val> [, <path>, <val>, ...])
パラメータ
| パラメータ | 説明 |
|---|---|
<jsonStr> | 挿入するJSONオブジェクト。NULL を含む任意の型の要素を持つJSONオブジェクトを指定できます。要素が指定されていない場合は、空の配列が返されます。json_str が有効なJSONでない場合、またはいずれかのパスパラメータが有効なパス式でない場合や * ワイルドカードを含む場合は、エラーが返されます。 |
<jsonPath> | 挿入するJSONパス。NULL の場合は、NULL を返します。 |
<val> | JSONに挿入する値。NULL の場合は、対応する位置にNULL値が挿入されます。 |
戻り値
JSON値を返します。
json_set 関数はJSON内のデータを挿入または更新し、結果を返します。json_str または path がNULLの場合はNULLを返します。それ以外の場合、json_str 引数が有効なJSONでない場合、またはいずれかのpath引数が有効なパス式でない場合や * ワイルドカードを含む場合はエラーが発生します。
パス-値のペアは左から右へ評価されます。
json内の既存のパスに対するパス-値ペアは、既存のjson値を新しい値で上書きします。json内の存在しないパスに対するパス-値ペアは、そのパスが以下のいずれかの値の型を識別する場合にjsonに値を追加します:
-
既存のオブジェクトに存在しないメンバー。メンバーがオブジェクトに追加され、新しい値と関連付けられます。
-
既存の配列の末尾を超えた位置。配列は新しい値で拡張されます。既存の値が配列でない場合は、配列として自動的にラップされ、その後新しい値で拡張されます。
それ以外の場合、json内の存在しないパスに対するパス-値ペアは無視され、効果がありません。
例
select json_set(null, null, null);
+------------------------------+
| json_set(NULL, NULL, 'NULL') |
+------------------------------+
| NULL |
+------------------------------+
select json_set('{"k": 1}', "$.k", 2);
+------------------------------------+
| json_set('{\"k\": 1}', '$.k', '2') |
+------------------------------------+
| {"k":2} |
+------------------------------------+
select json_set('{"k": 1}', "$.j", 2);
+------------------------------------+
| json_set('{\"k\": 1}', '$.j', '2') |
+------------------------------------+
| {"k":1,"j":2} |
+------------------------------------+