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;
相关推荐
BoomHe2 小时前
Kotlin shareIn 和 stateIn 使用场景
android·kotlin·android jetpack
pe7er2 小时前
MySQL 8 中大小写敏感与不敏感排序规则的选择
mysql
张雨zy2 小时前
Vue 的 v-if 与 v-show,Android 的 GONE 与 INVISIBLE
android·前端·vue.js
泯仲2 小时前
从零起步学习MySQL 第十三章:MySQL 事务详解:原理、特性、并发问题与隔离级别
数据库·学习·mysql
西门吹雪分身2 小时前
ShardingSphere-JDBC水平分片
mysql·shardingjdbc
0xDevNull2 小时前
MySQL的索引下推(ICP)
sql·mysql
倔强的石头1063 小时前
数据库迁移 TCO 全景账本:MySQL 替代中的隐性成本与工程化工具链实测
数据库·mysql·kingbase
电商API&Tina3 小时前
1688跨境寻源通API数据采集: 获得1688商品详情关键字搜索商品按图搜索1688商品
大数据·前端·数据库·人工智能·爬虫·json·图搜索算法
小龙加油!!!3 小时前
k8s 部署中间件(mysql、redis、minio、nacos)并持久化数据
mysql·中间件·kubernetes