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

相关推荐
枫叶丹421 小时前
国产数据库新标杆:金仓以多模融合重构文档数据库未来
开发语言·数据库·重构
m0_7482523821 小时前
Servlet 数据库访问
数据库·servlet
啟明起鸣21 小时前
【C++ 面向对象编程】补档:线程池和 MySQL 连接池的设计模式分析
开发语言·c++·mysql
liux352821 小时前
MySQL事务机制深度解析:从理论到实践(五)
数据库·mysql
二哈喇子!21 小时前
MySQL和Navicat怎么连接
数据库·mysql·navicat
静听山水21 小时前
StarRocks vs MySQL 全面深度对比
数据库
文亭湖畔程序猿21 小时前
PVE 基础环境初始化与 Debian Cloud-Init 部署记录
网络·数据库·debian
山峰哥21 小时前
数据库工程实战:一招实现 SQL 查询速度 10 倍提升
android·数据库·sql·编辑器·深度优先
中环留念21 小时前
MySQL的索引语法详解
数据库·mysql·索引