MySQL对JSON数据内对象进行更新

sql 复制代码
UPDATE
  表名
SET
  字段名 = 
  CASE WHEN
  JSON_EXTRACT(字段名,'$.字段里的对象名.对象内部字段名') IS NOT NULL
  THEN
  JSON_SET (
    字段名,
    "$.字段里的对象.对象内部字段",
    更新后的值
  )
  ELSE
   JSON_INSERT (
    字段名,
    "$.字段里的对象名",
    JSON_OBJECT("对象内部字段名",更新后的值)
  )
  END;
WHERE
  具体条件

以上SQL用于更新JSON结构数据内部的对象,不存在则插入,非对象的键值、对象多层嵌套同理,业务复杂时建议使用java代码转换为JSONObject处理。

例如存在 bill 账单表,定义了 text 类型的字段 bill_extension 以存储JSON数据,有一条数据为 {"customerCode": "a", "commodity": {"price": 10,"num":1}} ,把 commodity 对象里的 price 改为20。

sql 复制代码
UPDATE
  bill
SET
  bill_extension = 
  CASE WHEN
  JSON_EXTRACT(bill_extension,'$.commodity.price') IS NOT NULL
  THEN
  JSON_SET (
    bill_extension,
    "$.commodity.price",
    20
  )
  ELSE
   JSON_INSERT (
    bill_extension,
    "$.commodity",
    JSON_OBJECT("price",20)
  )
  END
WHERE
  id = 1;

注意点:

1.请根据具体业务情况替换代码的中文注释,并确认存储数据符合JSON格式。

2.MySQL5.7以下版本不支持JSON相关函数。

3.更新后JSON数据会按照一定规则重新排序,暂不了解具体细节,有知道的朋友欢迎指点。

4.JSON相关函数介绍推荐以下博客

【MySQL】对JSON数据操作(全网最全)_mysql json_0世界和平0的博客-CSDN博客

相关推荐
hnlucky18 分钟前
redis 数据类型新手练习系列——Hash类型
数据库·redis·学习·哈希算法
丘山子24 分钟前
一些鲜为人知的 IP 地址怪异写法
前端·后端·tcp/ip
CopyLower1 小时前
在 Spring Boot 中实现 WebSockets
spring boot·后端·iphone
LucianaiB1 小时前
【金仓数据库征文】_AI 赋能数据库运维:金仓KES的智能化未来
运维·数据库·人工智能·金仓数据库 2025 征文·数据库平替用金仓
时序数据说1 小时前
时序数据库IoTDB在航空航天领域的解决方案
大数据·数据库·时序数据库·iotdb
.生产的驴2 小时前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
景天科技苑2 小时前
【Rust】Rust中的枚举与模式匹配,原理解析与应用实战
开发语言·后端·rust·match·enum·枚举与模式匹配·rust枚举与模式匹配
AnsenZhu2 小时前
2025年Redis分片存储性能优化指南
数据库·redis·性能优化·分片
Johny_Zhao2 小时前
MySQL 高可用集群搭建部署
linux·人工智能·mysql·信息安全·云计算·shell·yum源·系统运维·itsm
oydcm2 小时前
MySQL数据库概述
数据库·mysql