首页 > 数据库 >MySQL中使用JSON存储数据

MySQL中使用JSON存储数据

时间:2023-07-22 17:44:20浏览次数:47  
标签:存储 name age 字段 JSON MySQL table data

1.概述:

MySQL从5.7版本开始引入了对JSON数据类型的原生支持。
这个增强功能使开发人员能够直接在数据库中存储、操作和查询JSON数据。

MySQL的JSON字段为存储半结构化数据提供了更加灵活和高效的方式。
相比传统的关系型数据库,使用JSON字段的优势包括:

  • 灵活性:JSON字段可以存储不同结构的数据,无需提前定义表结构。
  • 扩展性:可以轻松地添加新的属性或字段,无需修改表结构。
  • 快速开发:适用于那些数据结构经常变化或者需要快速迭代开发的应用。

2.使用:

要在MySQL中定义JSON字段,只需在创建表列时将数据类型指定为JSON即可。然后可以使用适当的语法将JSON数据插入到JSON字段中。以下是一个简单的示例:

CREATE TABLE my_table (
    id INT PRIMARY KEY,
    data JSON
);

INSERT INTO my_table VALUES (1, '{"name": "Tom", "age": 30}'), (2, '{"name": "Jerry", "age": 20}');

需要注意的是,在插入JSON类型的字符串时,MySQL会对JSON字符串进行格式校验,如果格式有误,就无法插入。

3.查询:

MySQL提供了强大的函数和运算符来查询JSON字段。可以使用->运算符从JSON字段中提取特定值,或使用->>运算符将值提取为字符串。以下是一个示例:

SELECT data->"$.name" AS name, data->"$.age" AS age
FROM my_table;

查询结果:

name age
"Tom" 30
"Jerry" 20

一样可以使用where语句:

SELECT data->"$.name" AS name, data->"$.age" AS age 
FROM my_table
WHERE data->"$.age" > 25;

查询结果:

name age
"Tom" 30

4.修改

  • 修改data中的age字段:
UPDATE my_table 
SET `data` = JSON_SET(`data`, "$.age", 31)
WHERE id = 1;
  • data中添加gender字段:
UPDATE my_table 
SET `data` = JSON_MERGE(`data`, '{"gender":"male"}')
WHERE id = 1;

5.删除

  • data中删除gender字段:
UPDATE my_table
SET `data` = JSON_REMOVE(`data`, "$.gender")
WHERE id = 1;

6.排序

MySQL中的JSON字段不支持直接排序。但是,我们可以使用带有->>运算符的ORDER BY子句根据特定的JSON字段对结果集进行排序。例如:

SELECT *
FROM my_table
ORDER BY data->>"$.age";

查询结果:

id data
2 {"age": 20, "name": "Jerry"}
1 {"age": 30, "name": "Tom"}

7.索引

JSON字段中,可以通过添加虚拟字段,来添加索引。

ALTER TABLE my_table 
add name VARCHAR(20) GENERATED ALWAYS AS (`data` ->> '$.name');

CREATE INDEX `name_idx` ON `my_table`(`name`);  

也可以在创建表的时候,同时生成虚拟字段和索引:

CREATE TABLE my_table (
    id INT PRIMARY KEY,
    data JSON,
    name VARCHAR(20) GENERATED ALWAYS AS (data->"$.name") VIRTUAL,
    INDEX name_idx (name)
);

8.实现原理:

在内部,MySQL使用一种优化的二进制格式(Binary JSON,简称BSON)来存储JSON数据。
这种格式可以高效地存储和检索JSON数据,提供高性能和较少的存储空间需求。

参考资料:

标签:存储,name,age,字段,JSON,MySQL,table,data
From: https://www.cnblogs.com/lcc9527/p/17573790.html

相关文章

  • python如何判断json中是否有某个字段
    项目方案:检查JSON中是否存在某个字段1.项目概述本项目旨在开发一个Python库,用于检查JSON数据中是否存在某个字段。通过对JSON数据进行解析和遍历,我们能够快速判断给定的字段是否存在于JSON中。2.项目需求用户能够将JSON数据作为输入,指定要查找的字段名称。程序能够遍历JSON......
  • MySQL的执行计划详解(Explain)
    MySQL的执行计划详解(Explain)1、MySQL执行计划的定义在MySQL中可以通过explain关键字模拟优化器执行SQL语句,从而知道MySQL是如何处理SQL语句的。2、MySQL整个查询的过程•客户端向MySQL服务器发送一条查询请求•服务器首先检查查询缓存,如果命中缓存,则立刻返回存储......
  • spring batch 框架进行元数据管理表 mysql
    使用SpringBatch框架进行元数据管理表MySQL的实现1.简介在进行大规模数据处理时,SpringBatch框架是一个非常有用的工具。它提供了一个强大的批处理框架,可以轻松地处理大量的数据,并具备事务管理、监控、错误处理等功能。为了进行元数据管理,我们可以使用MySQL数据库来存储和管理S......
  • 修改MySQL读写模式
    修改MySQL读写模式MySQL是一个开源的关系型数据库管理系统,广泛应用于互联网应用和企业级应用中。在MySQL中,存在着读写模式的设置,可以根据实际需求来调整数据库的读写性能和一致性。本文将介绍如何修改MySQL的读写模式,并提供代码示例。1.了解MySQL读写模式在MySQL中,有两种常见的......
  • 写shell脚本一键编译安装MySQL
    一键编译安装MySQL的Shell脚本在Linux系统中,MySQL是一个非常常见的数据库管理系统。它提供了强大的功能和可靠的性能,因此在许多应用程序中被广泛使用。为了在Linux系统上运行MySQL,我们需要先进行编译安装。为了简化这个过程,我们可以编写一个Shell脚本来自动完成MySQL的编译和安装......
  • 在mysql底下导出表数据
    在MySQL数据库中导出表数据是一个常见的任务,它允许我们将表数据以可移植的方式保存到文件中,以便在需要时重新导入到数据库中。这对于数据备份、数据迁移和与其他数据库系统的交互非常有用。在MySQL中,我们可以使用mysqldump命令来导出表数据。这是一个命令行工具,可以在终端中使用。......
  • MySQL之视图检查选项
    MySQL之视图检查选项视图的检查选项当使用WITHCHECKOPTION子句创建视图时,MySQL会通过视图检查正在更改的每个行,例如插入,更新,删除,以使其符合视图的定义。MySQL允许基于另一个视图创建视图,它还会检查依赖视图中的规则以保持一致性。为了确定检查的范围,mysql提供了两个选项:CASC......
  • file /usr/share/mysql/charsets/macroman.xml from install of MySQL-server-5.6
    MySQL服务器和字符集在使用MySQL数据库时,字符集是一个非常重要的概念。它决定了数据库中存储的数据如何表示和解释。MySQL支持多种字符集,每个字符集都有自己的编码方式和规则。在安装MySQL服务器时,我们可能会遇到如下错误提示信息:file/usr/share/mysql/charsets/macroma......
  • java 将json 转成对象数组
    将JSON转换为对象数组的步骤作为一名经验丰富的开发者,我将为你介绍如何将JSON数据转换为对象数组。这是一个非常常见的操作,而且在Java中也非常简单。下面是整个过程的步骤概览:步骤动作1.导入JSON库在你的项目中导入JSON库,以便能够处理JSON数据。2.创......
  • 计算机存储单元结构
    存储层次结构概况这是我们非常熟悉的冯·诺依曼计算机结构,那这其中哪些部件和存储功能有关呢?  存储器和外部记录介质肯定具有存储功能,另外还有一个自带存储功能的运算器,为了描述方便,我们把这些部件统称为存储器。那么我们看一下计算机中对存储器有哪些要求?1、首先存储器......