MySQL|通过JSON_UNQUOTE实现MySQL中JSON数据的干净提取

文章目录

JSON_UNQUOTE() 是 MySQL 中用于处理 JSON 数据类型的一个函数。它的主要作用是从 JSON 字符串中移除最外层的引号,这对于从 JSON 对象或数组中提取字符串值特别有用。

语法

sql 复制代码
JSON_UNQUOTE(json_string)
  • json_string: 这是你想要去掉引号的 JSON 字符串、对象或者数组元素。

使用示例

假设你有一个包含 JSON 数据的表 my_table,其中有一列 json_column,存储了如下 JSON 数据:

json 复制代码
{
  "name": "Alice",
  "age": 30,
  "city": "Wonderland"
}

如果你想查询 name 的值,并且不想要结果带有双引号,你可以使用 JSON_UNQUOTE() 函数:

sql 复制代码
SELECT JSON_UNQUOTE(JSON_EXTRACT(json_column, '$.name')) AS name
FROM my_table;

这将会返回 Alice 而不是 "Alice"

注意事项

  • 如果 json_string 不是有效的 JSON 格式,JSON_UNQUOTE() 将会返回 NULL
  • 如果 json_string 不是以引号包围的字符串(例如数字或布尔值),JSON_UNQUOTE() 仍然会正常工作,因为它不会尝试去移除不存在的引号。
  • JSON_UNQUOTE() 通常与 JSON_EXTRACT() 或者 -> 操作符一起使用来获取和清理 JSON 数据中的具体值。

希望这些信息能帮助更好地理解和使用 JSON_UNQUOTE() 函数。如果有更多关于 MySQL JSON 函数的问题,或者其他任何问题,欢迎一起讨论

相关推荐
前行的小黑炭31 分钟前
Android 协程的使用:结合一个环境噪音检查功能的例子来玩玩
android·java·kotlin
阿华的代码王国40 分钟前
【Android】内外部存储的读写
android·内外存储的读写
半夏陌离2 小时前
SQL 拓展指南:不同数据库差异对比(MySQL/Oracle/SQL Server 基础区别)
大数据·数据库·sql·mysql·oracle·数据库架构
敬业小码哥3 小时前
记一次:mysql的json及json数组使用组合使用
数据库·mysql·json
一键三联啊3 小时前
BSON 和 JSON 的区别
json
练小杰4 小时前
【Mysql-installer-community-8.0.26.0】Mysql 社区版(8.0.26.0) 在Window 系统的默认安装配置
数据库·sql·mysql·adb·配置文件·mysql安装·关系型数据库
inmK14 小时前
蓝奏云官方版不好用?蓝云最后一版实测:轻量化 + 不限速(避更新坑) 蓝云、蓝奏云第三方安卓版、蓝云最后一版、蓝奏云无广告管理工具、安卓网盘轻量化 APP
android·工具·网盘工具
giaoho4 小时前
Android 热点开发的相关api总结
android
感哥5 小时前
MySQL多表查询
mysql
咖啡の猫6 小时前
Android开发-常用布局
android·gitee