文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL中使用JSON存储数据

2023-08-31 07:31

关注

1.概述:

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

MySQL的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 ageFROM my_table;

查询结果:

nameage
“Tom”30
“Jerry”20

一样可以使用where语句:

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

查询结果:

nameage
“Tom”30

4.修改

UPDATE my_table SET `data` = JSON_SET(`data`, "$.age", 31)WHERE id = 1;
UPDATE my_table SET `data` = JSON_MERGE(`data`, '{"gender":"male"}')WHERE id = 1;

5.删除

UPDATE my_tableSET `data` = JSON_REMOVE(`data`, "$.gender")WHERE id = 1;

6.排序

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

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

查询结果:

iddata
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数据,提供高性能和较少的存储空间需求。

参考资料:

来源地址:https://blog.csdn.net/lch_boy/article/details/131869869

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯