在业务开发中,我们经常会收到前端或者其他系统传递过来的JSON格式数据,需要将这些数据拆分后存入关系型数据库的表中。如果手动逐个提取字段再拼接SQL语句,不仅开发效率低,还容易出现字段对应错误的问题。利用数据库自带的JSON_EXTRACT函数,可以直接在SQL语句中解析JSON内容,高效完成数据插入操作。

JSON_EXTRACT函数基础用法
JSON_EXTRACT是MySQL等支持JSON类型的数据库提供的原生函数,作用是从JSON文档中提取指定路径的数据。其基本语法如下:
JSON_EXTRACT(json_doc, path[, path] ...)
参数说明:
- json_doc:待解析的JSON字符串或者JSON类型的字段
- path:JSON的路径表达式,用来指定要提取的字段位置,路径以
$开头,对象字段用$.字段名表示,数组元素用$[索引]表示
比如我们有一个简单的JSON数据{"name": "张三", "age": 25, "city": "北京"},要提取name字段的值,SQL语句可以这样写:
SELECT JSON_EXTRACT('{"name": "张三", "age": 25, "city": "北京"}', '$.name') AS user_name;
执行结果会返回"张三",注意默认提取的结果是带双引号的,如果需要去掉双引号,可以配合JSON_UNQUOTE函数使用,或者直接使用->>操作符:
-- 两种方式都可以提取不带双引号的字段值
SELECT JSON_UNQUOTE(JSON_EXTRACT('{"name": "张三", "age": 25, "city": "北京"}', '$.name')) AS user_name;
SELECT '{"name": "张三", "age": 25, "city": "北京"}' ->> '$.name' AS user_name;
解析复杂JSON结构
提取嵌套对象字段
如果JSON中存在嵌套的对象,比如{"user": {"name": "李四", "age": 30}, "order_id": "1001"},要提取user下的name字段,路径需要写成$.user.name:
SELECT '{"user": {"name": "李四", "age": 30}, "order_id": "1001"}' ->> '$.user.name' AS user_name;
提取数组元素
如果JSON中包含数组,比如{"hobbies": ["篮球", "阅读", "旅行"], "name": "王五"},要提取数组中的第一个元素,路径写成$.hobbies[0],索引从0开始:
SELECT '{"hobbies": ["篮球", "阅读", "旅行"], "name": "王五"}' ->> '$.hobbies[0]' AS first_hobby;
结合INSERT语句完成数据插入
假设我们有一张用户表,表结构如下:
CREATE TABLE user_info (
id INT PRIMARY KEY AUTO_INCREMENT,
user_name VARCHAR(50),
user_age INT,
user_city VARCHAR(50)
);
现在要插入一条JSON数据{"name": "赵六", "age": 28, "city": "上海"},可以直接在INSERT语句中使用JSON_EXTRACT解析字段:
INSERT INTO user_info (user_name, user_age, user_city)
SELECT
JSON_UNQUOTE(JSON_EXTRACT('{"name": "赵六", "age": 28, "city": "上海"}', '$.name')),
JSON_EXTRACT('{"name": "赵六", "age": 28, "city": "上海"}', '$.age'),
JSON_UNQUOTE(JSON_EXTRACT('{"name": "赵六", "age": 28, "city": "上海"}', '$.city'));
如果JSON数据是存在表的某个JSON类型字段中,比如我们有一张临时表temp_json,其中有一个json_data字段存储JSON内容,要批量插入到user_info表,可以这样写:
INSERT INTO user_info (user_name, user_age, user_city)
SELECT
temp.json_data ->> '$.name',
temp.json_data ->> '$.age',
temp.json_data ->> '$.city'
FROM temp_json temp;
注意事项
- 使用JSON_EXTRACT时,如果路径不存在会返回NULL,插入时要注意字段是否允许为空,避免出现约束错误
- 如果JSON中的字段类型和目标表字段类型不匹配,比如JSON中提取的age是字符串类型,而表中user_age是INT类型,数据库会自动做隐式转换,但建议提前确认数据类型一致性
- 不同数据库的JSON解析函数略有差异,比如PostgreSQL使用
->和->>操作符,SQL Server使用JSON_VALUE函数,核心逻辑都是先解析JSON再拼接插入语句
JSON_EXTRACTSQLJSON数据插入修改时间:2026-06-29 18:33:27