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博客

相关推荐
REDcker4 小时前
HDR Vivid 技术介绍
数据库·算法·视频·sdr·屏幕·显示技术·dhr
冰暮流星4 小时前
sql语句之union语句
数据库·sql
2401_876381924 小时前
程序人生-Hello’s P2P
数据库·程序人生·p2p
VX:Fegn08954 小时前
计算机毕业设计|基于springboot + vue养老院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
湘-枫叶情缘5 小时前
从数据库写作到情绪工程:网络文学工程化转向的理论综述
数据库·人工智能
XuCoder5 小时前
零成本从0到1搭建个人博客
后端
heimeiyingwang5 小时前
企业非结构化数据的 AI 处理与价值挖掘
大数据·数据库·人工智能·机器学习·架构
山岚的运维笔记5 小时前
SQL Server笔记 -- 第63章:事务隔离级别
数据库·笔记·sql·microsoft·oracle·sqlserver
雨夜之寂5 小时前
大模型 ai coding 比较
后端·面试
白太岁5 小时前
Redis:(4) 缓存穿透、布隆过滤器与多级缓存
数据库·redis·缓存