使用JSON_EXTRACT匹配某个json类型字段中的某个具体字段

使用JSON_EXTRACT匹配某个json类型字段中的某个具体字段

  • [1. 使用场景](#1. 使用场景)
  • [2. 来自ChatGPT的`JSON_EXTRACT`使用说明](#2. 来自ChatGPT的JSON_EXTRACT使用说明)

1. 使用场景

  1. 如果你有一张表table,其中有一个字段attrs,并且该字段是一个json,其中又包括totalPrice、skuPrice、couponPrice三个字段;

  2. 而你现在只想查出数据库中skuPrice字段为0的记录;

  3. 那么这条SQL该怎么写呢?

  4. 如果是MySQL,可以使用JSON_EXTRACT,具体SQL语句如下:

    sql 复制代码
    SELECT * FROM table
    WHERE JSON_EXTRACT(attrs, '$.skuPrice') = 0;
  5. 如果是HiveSQL,可以使用get_json_object,具体SQL语句如下:

    sql 复制代码
    SELECT * FROM table
    WHERE get_json_object(attrs, '$.skuPrice') = 0;

2. 来自ChatGPT的JSON_EXTRACT使用说明

在MySQL中,JSON_EXTRACT是一个用于提取JSON数据中特定路径的函数。它接受两个参数:JSON文档和要提取的路径。

以下是JSON_EXTRACT函数的基本语法:
JSON_EXTRACT(json_doc, path)

  • json_doc是一个包含JSON数据的字段或表达式。
  • path是一个表示要提取的路径的字符串。

路径可以使用点号(.)来访问JSON对象的属性,也可以使用方括号([])来访问JSON数组的索引。例如,如果有以下JSON文档:

json 复制代码
{
  "employee": {
    "name": "John Doe",
    "age": 30,
    "departments": ["HR", "IT"]
  }
}

你可以使用JSON_EXTRACT函数来提取其中的值:

sql 复制代码
SELECT JSON_EXTRACT(json_doc, '$.employee.name') AS employee_name,
       JSON_EXTRACT(json_doc, '$.employee.departments[0]') AS first_department
FROM your_table;

在上面的例子中,我们使用JSON_EXTRACT函数从json_doc字段中提取了"employee"对象的"name"属性和"departments"数组的第一个元素。

另外,JSON_EXTRACT函数还支持更复杂的路径表达式,例如使用通配符*来匹配多个属性或索引。此外,还可以通过使用JSON_UNQUOTE函数来移除提取的结果中的引号,如果结果是一个字符串。

需要注意的是,JSON_EXTRACT函数在MySQL 5.7版本之后才可用,并且需要在MySQL中启用JSON功能。

相关推荐
刘大猫.23 分钟前
mysql数据库压缩
数据库·mysql·压缩·mysql数据库压缩·数据库压缩·数据库备份与压缩
会飞的架狗师28 分钟前
【MySQL体系】第4篇:MySQL 查询优化实用技巧
数据库·mysql
难以触及的高度1 小时前
Linux-CentOS 7 上安装 MySQL 8.0.43(保姆级教程)
linux·mysql·centos
武子康2 小时前
Java-144 深入浅出 MongoDB BSON详解:MongoDB核心存储格式与JSON的区别与应用场景
java·开发语言·数据库·mongodb·性能优化·json·bjson
Raymond运维2 小时前
MySQL包安装 -- SUSE系列(SUSE资源库安装MySQL)
linux·运维·数据库·mysql
白云偷星子4 小时前
MySQL笔记11
数据库·笔记·mysql
风随心飞飞6 小时前
linux 环境下mysql 数据库自动备份和清库 通过crontab 创建定时任务实现mysql数据库备份
linux·数据库·mysql
奥尔特星云大使6 小时前
读写分离中间件简介
数据库·mysql·中间件·读写分离
她说彩礼65万7 小时前
Asp.net core appsettings.json` 和 `appsettings.Development.json`文件区别
后端·json·asp.net
disanleya8 小时前
MySQL数据库安装后,如何设置自动化备份策略?
mysql