导读:本期聚焦于小伙伴创作的《如何将JSON格式数据直接插入SQL表_利用JSON_EXTRACT函数解析字段》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何将JSON格式数据直接插入SQL表_利用JSON_EXTRACT函数解析字段》有用,将其分享出去将是对创作者最好的鼓励。

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

如何将JSON格式数据直接插入SQL表_利用JSON_EXTRACT函数解析字段

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

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。