【MySQL】MySQL如何查询和筛选存储的JSON数据?

MySQL如何查询和筛选存储的JSON数据?

  • 一、背景介绍
  • 二、支持的JSON数据类型
  • 三、基础数据
    • 3.1 创建表
    • 3.2 插入 JSON 数据
    • 3.3 查询 JSON 数据
  • 四、操作函数
    • 4.1 JSON_OBJECT
    • 4.2 JSON_ARRAY
    • 4.3 JSON_EXTRACT

一、背景介绍

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,在现代应用程序中得到了广泛的应用。处理和存储非结构化数据变得越来越重要。MySQL 是一种常用的关系型数据库管理系统,为了支持非结构化数据的存储和查询,于是 MySQL引入了对JSON数据类型的支持。

MySQL从5.7.8版本开始添加了对JSON的支持,使得我们可以在MySQL数据库中存储和查询JSON格式的数据。本文将介绍如何使用MySQL查询和筛选存储的JSON数据,并提供相应的代码示例。

二、支持的JSON数据类型

从MySQL 5.7.8版本开始,MySQL引入了对JSON数据类型的支持。MySQL可以存储任意的JSON数据,包括对象、数组、字符串等。并且MySQL还对JSON数据类型还提供了一系列的操作函数和运算符,以便于对JSON数据进行查询和操作。

三、基础数据

3.1 创建表

DROP TABLE IF EXISTS `my_table`;
CREATE TABLE `my_table`  (`id` int NOT NULL,`message` json NULL,PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;SET FOREIGN_KEY_CHECKS = 1;

上述示例创建了一个名为 my_table 的表,包含一个名为 message 的JSON列。message列可以存储任意的JSON数据。

3.2 插入 JSON 数据

要在JSON列中插入数据,可以使用JSON函数将JSON字符串转换为JSON数据类型。以下是一个示例:

INSERT INTO `my_table` (`id`, `message`) VALUES (1, '{\"age\": 30, \"name\": \"John\"}');
INSERT INTO `my_table` (`id`, `message`) VALUES (2, '{\"age\": 40, \"name\": \"Mary\"}');
INSERT INTO `my_table` (`id`, `message`) VALUES (3, '{\"age\": 50, \"name\": \"Tom\"}');
INSERT INTO `my_table` (`id`, `message`) VALUES (4, '{\"age\": 60, \"name\": \"Jermy\"}');

上述示例在my_table表中插入了4条记录,其中 message 列包含一个JSON对象。

3.3 查询 JSON 数据

可以使用->或者->>运算符来查询JSON数据。->运算符返回JSON对象的属性值,->>运算符返回属性值的字符串表示。

以下是两个

查询JSON数据的示例1:

SELECT message->'$.name' AS name FROM my_table;

结果如下:

在这里插入图片描述

查询示例2:

SELECT * FROM my_table WHERE JSON_EXTRACT(message, '$.age') > 40

结果如下:

在这里插入图片描述

四、操作函数

MySQL提供了一系列的JSON数据操作函数,以方便对JSON数据进行查询和操作。以下是一些常用的JSON数据操作函数:

4.1 JSON_OBJECT

JSON_OBJECT函数用于创建一个JSON对象。以下是一个示例:

SELECT JSON_OBJECT('name', 'John', 'age', 30) AS message;

上述示例创建了一个名为 message 的JSON对象,包含name和age属性。

在这里插入图片描述

4.2 JSON_ARRAY

JSON_ARRAY函数用于创建一个JSON数组。以下是一个示例:

SELECT JSON_ARRAY('apple', 'banana', 'orange') AS fruits;

上述示例创建了一个名为fruits的JSON数组,包含三个元素。

在这里插入图片描述

4.3 JSON_EXTRACT

JSON_EXTRACT函数用于提取JSON数据中的值。以下是一个示例:

SELECT JSON_EXTRACT('{"name": "John", "age": 30}', '$.name') AS name;

上述示例从JSON数据中提取了name属性的值。

在这里插入图片描述

以上只是最基本的用法,关于MySQL操作JSON数据类型的函数还有很多高级用法,等用到的时候再学。

本文完结!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/319423.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

文心一言 VS 讯飞星火 VS chatgpt (171)-- 算法导论13.2 4题

四、用go语言,证明:任何一棵含n个结点的二叉搜索树可以通过 O(n)次旋转,转变为其他任何一棵含n个结点的二叉搜索树。(提示:先证明至多n-1次右旋足以将树转变为一条右侧伸展的链。) 文心一言: 这是一个有趣的问题&…

【JUC】Volatile关键字+CPU/JVM底层原理

Volatile关键字 volatile内存语义 1.当写一个volatile变量时,JMM会把该线程对应的本地内存中的共享变量值立即刷新回主内存中。 2.当读一个volatile变量时,JMM会把该线程对应的本地内存设置为无效,直接从主内存中读取共享变量 所以volatile…

【番外】【Airsim in Windows ROS in WSL2-Ubuntu20.04】环境配置大全

【番外】【Airsim in Windows &ROS in WSL2-Ubuntu20.04】环境配置大全 【前言(可省略不看)】1.在windows上面部署好UE4AirSim联合仿真环境2.在windows上面部署wsl2系统以及在wsl2上面部署ubuntu系统3.安装好ubuntu系统之后,目前只能在命…

使用开源 Upscayl 工具放大图片

Upscayl 是一个基于人工智能的图像放大工具,可以用来将低分辨率的图片放大到高分辨率。Upscayl 使用了一种称为超分辨率重建的技术,可以生成逼真的高分辨率图像。 在本教程中,我们将介绍如何使用 Upscaly 工具放大图片。 准备工作 下载&a…

基于Java在线考试管理系统设计与实现(源码+部署文档)

博主介绍: ✌至今服务客户已经1000、专注于Java技术领域、项目定制、技术答疑、开发工具、毕业项目实战 ✌ 🍅 文末获取源码联系 🍅 👇🏻 精彩专栏 推荐订阅 👇🏻 不然下次找不到 Java项目精品实…

geemap学习笔记040:GEE中样本点选择操作流程

前言 geemap中目前有一个bug,就是在选择样本点的时候不合理,选完一类样本之后,没法继续选择下一类,并且没法在线进行编辑和修改。因此目前就只能结合在线版的GEE进行样本选择,本节就详细的介绍一下GEE中样本点的选择过…

【EDA软件】国产嘉立创EDA使用

嘉立创(JLCPCB) 嘉立创(JLCPCB)提供的EDA专业版是一款在线的原理图设计与PCB设计工具,可以协助用户完成电子设计项目。以下是使用嘉立创EDA专业版的一般步骤: 注册与登录: 首先,你需…

【MySQL·8.0·源码】MySQL 表的扫描方式

前言 在进一步介绍 MySQL 优化器时,先来了解一下 MySQL 单表都有哪些扫描方式。 单表扫描方法是基表的读取基础,也是完成表连接的基础,熟悉了基表的基本扫描方式, 即可以倒推理解 MySQL 优化器层的诸多考量。 基表,即…

前端 js 基础(2)

js For In for in 循环遍历 person 对象每次迭代返回一个键 (x)键用于访问键的值键的值为 person[x] 如果索引顺序很重要,请不要在数组上使用 for in。 索引顺序依赖于实现,可能不会按照您期望的顺序访问数组值。 当顺序很重要时,最好使用 f…

【LeetCode每日一题】2487. 从链表中移除节点(调用栈+递归+翻转链表)

2024-1-3 文章目录 [2487. 从链表中移除节点](https://leetcode.cn/problems/remove-nodes-from-linked-list/)方法一:调用栈方法二:递归方法三:翻转链表 2487. 从链表中移除节点 方法一:调用栈 1.将所有节点按顺序压入栈中 2.从…

网页爬虫对于网络安全有哪些影响?

在当今信息爆炸的时代,网络已经成为人们获取信息、交流思想和开展业务的重要平台。然而,随着网络的普及和技术的不断发展,网络安全问题也日益凸显,其中网页爬虫对网络安全的影响不容忽视。本文将就网页爬虫对网络安全的影响进行深…

三分钟入门基于Visio的流程图绘制操作

Visio是微软旗下的一款流程图及其他框图绘制工具,有着广泛应用,其高效的展示功能和便捷快速的操作也广受认可。今天,我们就以最基本的流程图绘制为例来一起探索一下Visio的基础功能和用法。 声明:这篇教程从实用角度出发&#xf…