mysql json 数据操作

MySQL 支持 JSON 数据类型,并提供了多种函数来查询和操作 JSON 数据。以下是一些常用的 JSON 查询示例:

1. 创建包含 JSON 的表

首先,创建一个包含 JSON 列的表:

sql 复制代码
CREATE TABLE my_table (
    id INT AUTO_INCREMENT PRIMARY KEY,
    data JSON
);

2. 插入 JSON 数据

插入 JSON 数据到表中:

sql 复制代码
INSERT INTO my_table (data) VALUES
('{"name": "Alice", "age": 30, "city": "New York"}'),
('{"name": "Bob", "age": 25, "city": "Los Angeles"}');

3. 查询 JSON 数据

3.1 使用 JSON_EXTRACT

提取 JSON 字段的特定值:

sql 复制代码
SELECT JSON_EXTRACT(data, '$.name') AS name FROM my_table;
3.2 使用 -> 操作符

也可以使用简化的 -> 操作符来提取值:

sql 复制代码
SELECT data->'$.name' AS name FROM my_table;
3.3 使用 JSON_UNQUOTE

如果你想去掉引号,可以结合使用 JSON_UNQUOTE

sql 复制代码
SELECT JSON_UNQUOTE(data->'$.name') AS name FROM my_table;

4. 查询包含特定值的行

使用 JSON_CONTAINS 检查 JSON 中是否包含特定值:

sql 复制代码
SELECT * FROM my_table
WHERE JSON_CONTAINS(data, '"Alice"', '$.name');

5. 更新 JSON 数据

更新 JSON 中的特定字段:

sql 复制代码
UPDATE my_table
SET data = JSON_SET(data, '$.age', 31)
WHERE JSON_UNQUOTE(data->'$.name') = 'Alice';

6. 删除 JSON 中的字段

删除 JSON 中的特定字段:

sql 复制代码
UPDATE my_table
SET data = JSON_REMOVE(data, '$.city')
WHERE JSON_UNQUOTE(data->'$.name') = 'Bob';

7. 查询 JSON 数组

如果 JSON 数据是数组,可以使用 JSON_ARRAYJSON_CONTAINS

sql 复制代码
INSERT INTO my_table (data) VALUES
('{"name": "Charlie", "hobbies": ["reading", "traveling"]}');

SELECT * FROM my_table
WHERE JSON_CONTAINS(data->'$.hobbies', '"reading"');

总结

MySQL 的 JSON 查询功能非常强大,允许灵活地存储和操作半结构化数据。如果你有特定的场景或问题,请告诉我,我可以提供更详细的帮助!

相关推荐
分享牛6 小时前
Operaton入门到精通23-Operaton 2.0 原生支持 JUnit 6 核心指南
数据库·junit
编码忘我6 小时前
mysq系列之事务
数据库
知识分享小能手6 小时前
Redis入门学习教程,从入门到精通,Redis进阶编程知识点详解(5)
数据库·redis·学习
MekoLi296 小时前
MongoDB 新手完全指南:从入门到精通的实战手册
数据库·后端
cyforkk6 小时前
Spring AOP 进阶:揭秘 @annotation 参数绑定的底层逻辑
java·数据库·spring
2401_884970617 小时前
用Pygame开发你的第一个小游戏
jvm·数据库·python
麦聪聊数据7 小时前
快速将Oracle数据库发布为 API:使用 QuickAPI 实现 SQL2API
数据库·sql·低代码·oracle·restful
6+h7 小时前
【Redis】数据结构讲解
数据结构·数据库·redis
ID_180079054737 小时前
小红书笔记详情 API 接口系列 + 标准 JSON 返回参考(完整版)
数据库·笔记·json
wertyuytrewm7 小时前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python