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;
相关推荐
總鑽風2 分钟前
数据一致性springcloud+rabbitmq+mysql+redis
mysql·spring cloud·rabbitmq
我就是马云飞5 分钟前
停更5年后,我为什么重新开始写技术内容了
android·前端·程序员
墨神谕20 分钟前
什么是回表查询
mysql
草莓熊Lotso23 分钟前
MySQL 事务管理全解:从 ACID 特性、隔离级别到 MVCC 底层原理
linux·运维·服务器·c语言·数据库·c++·mysql
stevenzqzq28 分钟前
Kotlin 协程:withContext 与 async 核心区别与使用场景
android·开发语言·kotlin
唔6632 分钟前
原生 Android(Kotlin)仅串口「侵入式架构」完整案例三
android·架构·kotlin
唔6632 分钟前
原生 Android(Kotlin)仅串口「可插拔架构」完整案例一
android·架构·kotlin
Melrose38 分钟前
移动端安全攻防
android·前端·安全
不愿透露姓名的大鹏1 小时前
MySQL InnoDB核心参数深度优化/性能调优
运维·服务器·数据库·mysql
葡萄城技术团队1 小时前
Claude Code Buddy 小析:一个非核心功能,如何体现产品的细节完成度
android·java·microsoft