mysql 如何使用JSON_EXTRACT() 取json值

当mysql存储JSON格式的数据时,我们需要对JSON进行提取。MySQL 5.7版本以上,提供了JSON_EXTRACT()函数来实现从JSON中提取值。

JSON_EXTRACT()函数的语法

JSON_EXTRACT(json_path)

json_path为JSON路径参数,返回该路径下的JSON值。

示例1

已知json字段'data'的值为:

{
  "name": "Tom",
  "age": 20,
  "address": {
    "province": "Guangdong",
    "city": "Shenzhen",
    "district": "Futian"
  },
  "friends": [
    {"name": "John", "age": 22},
    {"name": "Bob", "age": 21}
  ]
}

我们想要获取Tom的名字,可以使用以下语句:

SELECT JSON_EXTRACT(data, "$.name") AS username FROM table;

这里JSON_EXTRACT()函数将返回"name"字段对应的值"Tom"。

示例2

已知json字段'data'的值为:

{
  "product": {
    "id": "12345",
    "name": "手机",
    "price": {
      "sale": {
        "amount": 1999.00,
        "currency": "RMB"
      }
    }
  }
}

我们想要获取商品名称以及商品的售价,我们可以使用以下代码:

SELECT 
  JSON_EXTRACT(data, "$.product.name") AS product_name,
  JSON_EXTRACT(data, "$.product.price.sale.amount") AS product_price
FROM table;

这里JSON_EXTRACT()函数将返回"value"字段对应的值"手机"以及"amount"字段对应的值1999.00。

注意:需要使用双引号将json_path包围起来。

除了JSON_EXTRACT()函数以外,还有其他JSON处理函数,如JSON_CONTAINS()和JSON_ARRAYAGG()等。这些函数在处理JSON数据时提供了很大的便利。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:mysql 如何使用JSON_EXTRACT() 取json值 - Python技术站

(0)
上一篇 2023年5月23日
下一篇 2023年5月23日

相关文章

  • C程序 检查一个数字是否为 Palindrome

    首先,需要明确Palindrome的定义:一个数字是Palindrome,当且仅当它的数字顺序倒过来后仍然相同。例如,121是Palindrome,而123不是Palindrome。 接下来,我们来介绍如何在C程序中检查一个数字是否为Palindrome。以下是完整的使用攻略: 步骤一:将数字转化为字符串 我们需要将要检查的数字转化为字符串,然后才能进行后续…

    C 2023年5月9日
    00
  • C/C++深入讲解内存管理

    C/C++深入讲解内存管理攻略 本篇攻略将会详细介绍C/C++中的内存管理,包括内存的分配和释放方式、内存泄漏与野指针等常见问题的解决方案,以及内存管理相关的工具和技巧。以下为详细介绍。 一、动态内存分配 C/C++中的动态内存分配主要通过malloc、realloc和calloc等函数来实现。其中,malloc和realloc都是只分配内存,而calloc…

    C 2023年5月23日
    00
  • C程序 将一个数组的所有元素复制到另一个数组

    下面我来详细讲解如何编写一份 C 程序来将一个数组的所有元素复制到另一个数组。 问题描述 假设有两个整型数组 arr1 和 arr2,现在的任务是将 arr1 的所有元素复制到 arr2 中。 思路分析 这个问题可以通过创建一个循环来实现,遍历 arr1 的所有元素并将其逐个复制到 arr2 中。因此,我们将创建一个 for 循环,并在循环中执行一个赋值操作…

    C 2023年5月9日
    00
  • Win10无法开机0xc0000225错误代码解决方法

    当我们开机时,有时可能会遇到Win10无法开机的问题,面对这种情况,我们需要对问题进行诊断,找到错误原因并解决问题。其中,“Win10无法开机0xc0000225错误代码解决方法”就是我们需要掌握的一种处理方法。 什么是0xc0000225错误代码? 0xc0000225错误代码是指系统启动时,所需要加载的winload.exe文件出现错误或缺失引起的错误。…

    C 2023年5月23日
    00
  • 用C语言实现井字棋游戏代码

    用C语言实现井字棋游戏代码 1. 程序框架 首先,我们需要理解井字棋游戏的规则,然后设计程序框架。井字棋通常是由两个玩家交替下棋,棋盘为 3×3 的矩阵,玩家通过落子来使自己的棋子连成一条直线。因此,我们需要至少维护以下信息: 棋盘状态,即每个位置的落子情况; 游戏进程状态,即当前轮到哪个玩家下棋,或者游戏是否结束。 接下来,我们可以设计井字棋程序的结构体,…

    C 2023年5月24日
    00
  • c#学习教程之JSON文件及解析实例

    那么让我们来详细讲解一下“c#学习教程之JSON文件及解析实例”的完整攻略吧。这个教程主要分为以下几个部分: 1. 什么是JSON? 我们先来回答一个非常基础的问题,什么是JSON?JSON是JavaScript Object Notation的缩写,是一种轻量级的数据交换格式。它是一种文本格式,易于理解和生成,同时也易于解析和使用。它是基于JavaScri…

    C 2023年5月23日
    00
  • C语言中双链表的基本操作

    下面是C语言中双链表的基本操作的完整攻略。 双链表的基本操作 什么是双链表 双向链表(Doubly linked list)是链表的一种,它同样由一系列的节点组成,每个结点分别含有指向前驱和后继结点的两个指针。这种结构允许双向遍历。常见的操作有前插、后插、删除、查找等,下面详细介绍其基本操作。 双链表的结构 双链表的结构如下所示: struct node{ …

    C 2023年5月24日
    00
  • C语言的进制转换及算法实现教程

    C语言的进制转换及算法实现教程 概述 在计算机科学和编程中,进制转换是一个重要的概念,它涉及到二进制、十进制、八进制与十六进制之间的相互转换。C语言作为一种非常流行和强大的编程语言,也支持这些进制之间的转换。 本教程将向您介绍C语言中进制转换的基本概念和算法,以及如何在代码中实现这些转换过程。 进制转换的基本概念 二进制:由0和1组成,是计算机中最基本的数字…

    C 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部