【MySQL】MySQL函数之JSON_EXTRACT

在 MySQL 中,JSON_EXTRACT() 函数用于从 JSON 文档中提取一个或多个值。这个函数非常有用,特别是在处理存储在 JSON 格式中的复杂数据时。下面是一些关于如何使用 JSON_EXTRACT() 的详细说明和示例。

基本语法

sql 复制代码
JSON_EXTRACT(json_doc, path [, path] ...)
  • json_doc: 要从中提取值的 JSON 文档。
  • path: 一个或多个路径表达式,用于指定要提取的值的位置。路径表达式以 $ 开头,表示 JSON 文档的根。

路径表达式

路径表达式使用类似于 JavaScript 的对象和数组访问语法:

  • 对象属性:使用点 . 访问,例如 $.name
  • 数组元素:使用方括号 [] 访问,例如 $[0]
  • 嵌套结构:可以组合使用点和方括号,例如 $.address.street$.items[0].name

示例

示例 1: 提取简单值

假设有一个表 users,其中有一个字段 data 存储了用户的 JSON 数据:

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

INSERT INTO users (id, data) VALUES
(1, '{"name": "Alice", "age": 30, "city": "New York"}'),
(2, '{"name": "Bob", "age": 25, "city": "Los Angeles"}');

我们可以使用 JSON_EXTRACT() 提取每个用户的名字:

sql 复制代码
SELECT id, JSON_EXTRACT(data, '$.name') AS name
FROM users;

输出结果:

复制代码
+----+--------+
| id | name   |
+----+--------+
| 1  | "Alice"|
| 2  | "Bob"  |
+----+--------+
示例 2: 提取嵌套值

假设 JSON 数据中包含嵌套的对象:

sql 复制代码
INSERT INTO users (id, data) VALUES
(3, '{"name": "Charlie", "age": 35, "address": {"street": "123 Main St", "city": "Chicago"}}');

我们可以提取嵌套的街道地址:

sql 复制代码
SELECT id, JSON_EXTRACT(data, '$.address.street') AS street
FROM users;

输出结果:

复制代码
+----+-----------------+
| id | street          |
+----+-----------------+
| 1  | NULL            |
| 2  | NULL            |
| 3  | "123 Main St"   |
+----+-----------------+
示例 3: 提取数组中的值

假设 JSON 数据中包含一个数组:

sql 复制代码
INSERT INTO users (id, data) VALUES
(4, '{"name": "David", "age": 40, "hobbies": ["reading", "traveling", "cooking"]}');

我们可以提取数组中的第一个爱好:

sql 复制代码
SELECT id, JSON_EXTRACT(data, '$.hobbies[0]') AS hobby
FROM users;

输出结果:

复制代码
+----+----------+
| id | hobby    |
+----+----------+
| 1  | NULL     |
| 2  | NULL     |
| 3  | NULL     |
| 4  | "reading"|
+----+----------+

注意事项

  • JSON_EXTRACT() 返回的结果是一个 JSON 值,即使它是标量值(如字符串或数字)。如果需要将结果转换为标量类型,可以使用 CAST 函数。例如:

    sql 复制代码
    SELECT id, CAST(JSON_EXTRACT(data, '$.name') AS CHAR) AS name
    FROM users;
  • 如果路径表达式指向的值不存在,JSON_EXTRACT() 将返回 NULL

  • 路径表达式中的索引是从 0 开始的。

相关推荐
早日退休!!!13 小时前
Roofline模型核心原理:延迟、吞吐与并发的底层逻辑
大数据·网络·数据库
砚边数影13 小时前
KingbaseES基础(二):SQL进阶 —— 批量插入/查询 AI 样本数据实战
java·数据库·人工智能·sql·ai
霖霖总总13 小时前
[小技巧35]深入 InnoDB 的 LRU 机制:从原理到调优
数据库·mysql·性能优化
Coder_Boy_13 小时前
基于SpringAI的在线考试系统-考试系统DDD(领域驱动设计)实现步骤详解(2)
java·前端·数据库·人工智能·spring boot
风行無痕13 小时前
MySQL 8.4 数据库修改字段长度的过程
数据库·mysql
難釋懷14 小时前
Redis命令-Hash命令
数据库·redis·哈希算法
難釋懷14 小时前
Redis命令-List命令
数据库·redis·list
zqmattack14 小时前
SQL sever根据身份证判断性别函数
java·数据库·sql
hanqunfeng14 小时前
(七)Redis 命令及数据类型 -- Hash
数据库·redis·哈希算法