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

相关推荐
时序数据说20 分钟前
时序数据库的存储之道:从数据特性看技术要点
大数据·数据库·物联网·开源·时序数据库·iotdb
鸥梨菌Honevid1 小时前
QT解析文本框数据——概述
数据库·qt·mysql
今天又得骑车了1 小时前
一、MySQL 8.0 之《EXPLAIN ANALYZE 执行计划》
数据库·mysql·database
icecreamstorm1 小时前
MySQL 事务 最全入门
后端·mysql
weixin_420571872 小时前
Windos服务器升级MySQL版本
运维·服务器·mysql
万能小锦鲤2 小时前
《Java EE与中间件》实验三 基于Spring Boot框架的购物车
java·spring boot·mysql·实验报告·购物车·文档资源·java ee与中间件
Hoking2 小时前
CentOS7环境安装包部署并配置MySQL5.7
mysql
野犬寒鸦2 小时前
MyBatis-Plus 中使用 Wrapper 自定义 SQL
java·数据库·后端·sql·mybatis
我爱一条柴ya3 小时前
【AI大模型】RAG系统组件:向量数据库(ChromaDB)
数据库·人工智能·pytorch·python·ai·ai编程
北北~Simple3 小时前
第一次搭建数据库
服务器·前端·javascript·数据库