0

0

SQL JSON_EXTRACT 与 JSON_UNQUOTE 使用

舞夢輝影

舞夢輝影

发布时间:2026-02-19 11:57:36

|

529人浏览过

|

来源于php中文网

原创

json_extract返回带引号的json格式字符串,需用json_unquote解包或cast显式转换类型,路径错误时静默返回null,性能敏感场景应避免直接在where中使用而改用生成列加索引。

sql json_extract 与 json_unquote 使用

JSON_EXTRACT 返回的是带引号的字符串,不是你想要的纯值

MySQL 的 JSON_EXTRACT 从不自动去掉外层双引号——哪怕提取的是字符串、数字或布尔值,结果都是 JSON 文本格式。比如 JSON_EXTRACT('{"name":"alice"}', '$.name') 返回 "\"alice\""(即带转义双引号的字符串),不是 "alice"

这会导致常见错误:用在 WHEREORDER BY 里匹配失败、拼接时多出引号、跟整数比较返回 NULL

  • 提取数字时:JSON_EXTRACT('{"age":25}', '$.age') 得到 "25"(字符串),不能直接和 25 比较
  • 提取布尔值时:JSON_EXTRACT('{"active":true}', '$.active') 得到 "true"(小写字符串),不是布尔类型 TRUE
  • IN 子句中直接用会报错或逻辑错,因为类型不匹配

JSON_UNQUOTE 是解包必需步骤,但不能乱套

JSON_UNQUOTE 的作用就是剥掉 JSON_EXTRACT 外层的双引号和转义,把 JSON 字符串还原成常规 MySQL 值。但它只处理最外层引号,不解析嵌套结构,也不做类型转换。

典型正确用法是套在 JSON_EXTRACT 外面:JSON_UNQUOTE(JSON_EXTRACT(data, '$.name'))。但注意它对非字符串值(如 nulltruefalse)无效,会原样返回(JSON_UNQUOTE('null') 还是 'null' 字符串)。

  • 对字符串字段必须用:JSON_UNQUOTE(JSON_EXTRACT(...))
  • 对数字字段,更稳妥的是用 CAST(... AS SIGNED)CAST(... AS DECIMAL) 显式转类型
  • JSON_UNQUOTENULL 输入返回 NULL,但对无效 JSON 路径返回 NULL,容易掩盖路径写错的问题

JSON_EXTRACT 路径错误时静默返回 NULL,很难 debug

JSON_EXTRACT 遇到不存在的 key、错误的数组下标、或非法路径(如 $..foo 在旧版 MySQL 不支持),一律返回 NULL,不报错也不警告。你看到 NULL,可能是数据真为空,也可能是路径写错了。

成新网络商城购物系统
成新网络商城购物系统

使用模板与程序分离的方式构建,依靠专门设计的数据库操作类实现数据库存取,具有专有错误处理模块,通过 Email 实时报告数据库错误,除具有满足购物需要的全部功能外,成新商城购物系统还对购物系统体系做了丰富的扩展,全新设计的搜索功能,自定义成新商城购物系统代码功能代码已经全面优化,杜绝SQL注入漏洞前台测试用户名:admin密码:admin888后台管理员名:admin密码:admin888

下载

调试建议优先用 JSON_VALID() 确认字段内容合法,再用 JSON_KEYS()JSON_CONTAINS_PATH() 检查路径是否存在。

  • SELECT JSON_CONTAINS_PATH(data, 'one', '$.user.name') FROM t; 返回 1 表示路径存在
  • SELECT JSON_KEYS(data) FROM t LIMIT 1; 快速看顶层 key
  • 避免用 $.. 深度搜索(MySQL 5.7 不支持,8.0+ 才支持,且性能差)

性能敏感场景别在 WHERE 里反复 JSON_EXTRACT

每次调用 JSON_EXTRACT 都要解析整个 JSON 字段,如果在 WHEREORDER BY 中高频使用,会显著拖慢查询,尤其大表或复杂 JSON。

真实业务中,稳定字段(如 statuscategory)应该拆成普通列并加索引;临时分析可建生成列(Generated Column)+ 索引:

ALTER TABLE orders ADD COLUMN status VARCHAR(20) 
  AS (JSON_UNQUOTE(JSON_EXTRACT(metadata, '$.status'))) STORED;

然后对 status 加索引。否则,WHERE JSON_EXTRACT(...) = 'done' 基本无法走索引。

MySQL 5.7+ 支持对 JSON 列建函数索引,但仅限于 JSON_EXTRACT + JSON_UNQUOTE 组合,且必须是确定性表达式;稍有偏差(比如加了 TRIM)就失效。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

985

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

377

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1738

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

374

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1292

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

436

2024.04.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 9.4万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号