MySQL修改JSON格式数据示例

最近发现有个数据是用JSON格式直接存到表格里面的,大概就是下面这样的

然后需要修改里面某个属性的值,一开始我想的是 REPLACE 替换

sql 复制代码
UPDATE test_1 SET content = REPLACE(content, '{"age": 15, "name": "w5"}', '{"age": 20, "name": "20"}')

可以发现也能实现

但总觉得不大对劲,所以去搜了一下,发现两个以前没用过的方法 JSON_REPLACE 和 JSON_SET

我们先来试一下 JSON_REPLACE

sql 复制代码
UPDATE test_1 SET content = JSON_REPLACE(content, '$.name', "w5") WHERE id = 3

再来试下 JSON_SET

sql 复制代码
UPDATE test_1 SET content = JSON_SET(content, '$.age', 15) WHERE id = 3

发现这三个都能实现我们的目的,那这三个有什么区别

特性 REPLACE JSON_SET JSON_REPLACE
作用对象 字符串中的子字符串 JSON 数据中的键值对 JSON 数据中的已存在键值对
是否考虑 JSON 结构 不考虑,简单的字符替换 处理 JSON 数据,修改或新增键值对 处理 JSON 数据,仅替换已存在的键值对
新增键值对 不支持 支持,如果路径不存在会新增 不支持,路径不存在时不做任何操作
修改现有键值对 不适用于 JSON 键值对的修改 支持,修改路径存在的键值对 支持,只修改路径存在的键值对
适用场景 字符串替换,适合非结构化数据 修改 JSON 数据或新增键值对 只需要替换 JSON 中已存在的键值对时使用
是否破坏数据结构 可能会破坏 JSON 结构 不会破坏 JSON 结构 不会破坏 JSON 结构,确保数据一致性
相关推荐
dd06s7 分钟前
安卓上传依赖到maven私有仓库
android·java·maven
minji...15 分钟前
MySQL数据库 (六) MySQL表的约束(下),自增长约束,唯一键约束,外键约束,索引
数据库·mysql·索引·外键·唯一键·外键约束·自增长约束
程序员陆业聪22 分钟前
开发人员的汇报指南:故障、复盘、问题、阶段任务、人员情况,五种场景全覆盖
android
杉氧25 分钟前
Kotlin 协程深度解析③:流式编程——Flow 的响应式进化
android·kotlin
私人珍藏库31 分钟前
【Android】iTubeGo(去除限制)
android·智能手机·app·工具·多功能
wangbing112537 分钟前
MySQL的另类语法
数据库·mysql
2601_9547064939 分钟前
云手机虚拟化技术深度拆解:从安卓容器到 GPU 直通
android·智能手机
范特西林1 小时前
Android 16 AppFunction 机制分析
android·ai编程
Coffeeee1 小时前
Android16升级,预测性返回适配起来到底难不难
android·程序员·kotlin
_李小白1 小时前
【android opencv学习笔记】Day 33: 直线检测之图像轮廓检测
android·opencv·学习