json_replace

SinceVersion dev

Description

Syntax

VARCHAR json_replace(VARCHAR json_str, VARCHAR path, VARCHAR val[, VARCHAR path, VARCHAR val] ...)

json_replace 函数在 JSON 中更新数据并返回结果。如果 json_strpath 为 NULL,则返回 NULL。否则,如果 json_str 不是有效的 JSON 或任何 path 参数不是有效的路径表达式或包含了 * 通配符,则会返回错误。

路径值对按从左到右的顺序进行评估。

如果 JSON 中已存在某个路径,则路径值对会将现有 JSON 值覆盖为新值。 否则,对于 JSON 中不存在的某个路径的路径值对将被忽略且不会产生任何影响。

example

  1. MySQL> select json_replace(null, null, null);
  2. +----------------------------------+
  3. | json_replace(NULL, NULL, 'NULL') |
  4. +----------------------------------+
  5. | NULL |
  6. +----------------------------------+
  7. MySQL> select json_replace('{"k": 1}', "$.k", 2);
  8. +----------------------------------------+
  9. | json_replace('{\"k\": 1}', '$.k', '2') |
  10. +----------------------------------------+
  11. | {"k":2} |
  12. +----------------------------------------+
  13. MySQL> select json_replace('{"k": 1}', "$.j", 2);
  14. +----------------------------------------+
  15. | json_replace('{\"k\": 1}', '$.j', '2') |
  16. +----------------------------------------+
  17. | {"k":1} |
  18. +----------------------------------------+

keywords

JSON, json_replace