MySQL中JSON 格式字段里某个值修改

在 MySQL 中修改 JSON 格式字段里的某个 key 值,核心是使用 MySQL 提供的 JSON 专用函数,最常用的是 JSON_SET()(覆盖 / 新增)和 JSON_REPLACE()(仅覆盖已有值)。下面我会分场景给出具体用法,确保你能直接套用。

一、核心函数说明

先明确两个关键函数的区别:
JSON_SET(json_doc, path, val):修改已有 key 的值,若 key 不存在则新增
JSON_REPLACE(json_doc, path, val):仅修改已有 key 的值,key 不存在则无操作

path 格式规则:

根节点用 $ 表示

一级 key:$.key

嵌套 key:$.parent_key.child_key

数组元素:$.array_key[0](数组下标从 0 开始)

二、演练

假设你有一张表 user_info,结构如下:

sql 复制代码
CREATE TABLE user_info (
  id INT PRIMARY KEY AUTO_INCREMENT,
  info JSON -- 存储JSON的字段
);

-- 插入测试数据
INSERT INTO user_info (info) VALUES 
('{"name":"张三","age":20,"address":{"city":"北京","area":"朝阳"}}'),
('{"name":"李四","age":25,"hobbies":["篮球","游戏"]}');

场景 1:修改一级 JSON key 的值

修改 id=1 的用户 age 为 22

sql 复制代码
-- 方法1:用 JSON_SET(推荐,兼容性更强)
UPDATE user_info 
SET info = JSON_SET(info, '$.age', 22) 
WHERE id = 1;

-- 方法2:用 JSON_REPLACE(仅当age存在时生效)
UPDATE user_info 
SET info = JSON_REPLACE(info, '$.age', 22) 
WHERE id = 1;

场景 2:修改嵌套 JSON key 的值

修改 id=1 的用户 address.city 为 "上海":

sql 复制代码
UPDATE user_info 
SET info = JSON_SET(info, '$.address.city', '上海') 
WHERE id = 1;

场景 3:修改 JSON 数组中的元素

修改 id=2 的用户 hobbies 数组第 1 个元素(下标 0)为 "足球":

sql 复制代码
UPDATE user_info 
SET info = JSON_SET(info, '$.hobbies[0]', '足球') 
WHERE id = 2;
相关推荐
问心无愧05134 小时前
ctf show web入门111
android·前端·笔记
bjzhang758 小时前
CentOS下安装MySQL详解
linux·mysql·centos
十五年专注C++开发10 小时前
MySql中各种功能用sql语句实现总结
数据库·sql·mysql
ha_lydms11 小时前
AnalyticDB分区、分布键性能优化
android·大数据·分布式·性能优化·分布式计算·分区·analyticdb
星辰11 小时前
Ijkplayer重新编译支持h264裸流
android
测试开发-学习笔记11 小时前
Android studio安装
android·ide·android studio
宋拾壹11 小时前
同时添加多个类目
android·开发语言·javascript
ULIi096kr12 小时前
MySQL解决Too many connections报错:连接数爆满排查、优化与永久解决方案
数据库·mysql·adb
●VON12 小时前
AtomGit Flutter鸿蒙客户端:数据模型
android·服务器·安全·flutter·harmonyos·鸿蒙