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 结构,确保数据一致性
相关推荐
程序员Android3 分钟前
Android 相机MFNR 拍照trace 分析
android·数码相机
2501_915918414 分钟前
基于Mach-O文件的动态库与静态库归属方案及API扫描实践
android·ios·小程序·https·uni-app·iphone·webview
踏雪羽翼4 分钟前
android 实现google 订阅支付
android·支付·订阅·google订阅·谷歌支付
2501_915106327 分钟前
iOS 证书无法跨电脑使用?签名迁移方法一文讲透
android·ios·小程序·https·uni-app·iphone·webview
Kapaseker11 分钟前
Window 内外藏机巧 旧岗新页见真章
android·kotlin
谪星·阿凯20 分钟前
从XXE遗留疑问到Upload-Labs全通关:文件上传漏洞的溯源与实战突破
android·计算机网络
星轨初途20 分钟前
C++ 类和对象(下):初始化列表、static 成员与编译器优化深度剖析
android·开发语言·c++·经验分享·笔记
Seven9723 分钟前
揭秘MySQL索引分类
mysql
AI算法董同学33 分钟前
【MySQL】项目后端 MySQL 数据库初始化步骤
数据库·mysql·adb
云边有个稻草人38 分钟前
【MySQL】第十三节—索引:底层原理、B + 树演进、操作实战
mysql·索引·聚簇索引·主键索引·唯一键索引·普通索引·创建索引