【原创】MySQL5.7 JSON类型使用介绍

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

JSON是一种轻量级的数据交换格式,采用了独立于语言的文本格式,类似XML,但是比XML简单,易读并且易编写。对机器来说易于解析和生成,并且会减少网络带宽的传输。

JSON的格式非常简单:名称/键值。之前MySQL版本里面要实现这样的存储,要么用VARCHAR要么用TEXT大文本。 MySQL5.7发布后,专门设计了JSON数据类型以及关于这种类型的检索以及其他函数解析。 我们先看看MySQL老版本的JSON存取。


示例表结构:

1
2
3
4
CREATE  TABLE  json_test(
id  INT ,
person_desc TEXT
)ENGINE INNODB;

我们来插入一条记录:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
INSERT  INTO  json_test  VALUES  (1, '{
     "programmers": [{
         "firstName": "Brett",
         "lastName": "McLaughlin",
         "email": "aaaa"
     }, {
         "firstName": "Jason",
         "lastName": "Hunter",
         "email": "bbbb"
     }, {
         "firstName": "Elliotte",
         "lastName": "Harold",
         "email": "cccc"
     }],
     "authors": [{
         "firstName": "Isaac",
         "lastName": "Asimov",
         "genre": "sciencefiction"
     }, {
         "firstName": "Tad",
         "lastName": "Williams",
         "genre": "fantasy"
     }, {
         "firstName": "Frank",
         "lastName": "Peretti",
         "genre": "christianfiction"
     }],
     "musicians": [{
         "firstName": "Eric",
         "lastName": "Clapton",
         "instrument": "guitar"
     }, {
         "firstName": "Sergei",
         "lastName": "Rachmaninoff",
         "instrument": "piano"
     }]
}' );


那一般我们遇到这样来存储JSON格式的话,只能把这条记录取出来交个应用程序,有应用程序来解析。



现在到了MySQL5.7,我们重新修改下表结构:

1
ALTER  TABLE  json_test  MODIFY  person_desc json;


先看看插入的这行JSON数据有哪些KEY:

1
2
3
4
5
mysql>  SELECT  id,json_keys(person_desc)  as  "keys"  FROM  json_test\G
*************************** 1. row ***************************
   id: 1
keys: [ "authors" "musicians" "programmers" ]
1 row  in  set  (0.00 sec)


我们可以看到,里面有三个KEY,分别为authors,musicians,programmers。那现在找一个KEY把对应的值拿出来:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
mysql>  SELECT  json_extract(AUTHORS, '$.lastName[0]' AS  'name' , AUTHORS  FROM
     -> (
     ->  SELECT  id,json_extract(person_desc, '$.authors[0][0]' AS  "authors"  FROM  json_test
     ->  UNION  ALL
     ->  SELECT  id,json_extract(person_desc, '$.authors[1][0]' AS  "authors"  FROM  json_test
     ->  UNION  ALL
     ->  SELECT  id,json_extract(person_desc, '$.authors[2][0]' AS  "authors"  FROM  json_test
     -> )  AS  T1
     ->  ORDER  BY  NAME  DESC \G
*************************** 1. row ***************************
    name "Williams"
AUTHORS: { "genre" "fantasy" "lastName" "Williams" "firstName" "Tad" }
*************************** 2. row ***************************
    name "Peretti"
AUTHORS: { "genre" "christianfiction" "lastName" "Peretti" "firstName" "Frank" }
*************************** 3. row ***************************
    name "Asimov"
AUTHORS: { "genre" "sciencefiction" "lastName" "Asimov" "firstName" "Isaac" }
rows  in  set  (0.00 sec)



现在来把详细的值罗列出来:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
mysql>  SELECT
     -> json_extract(AUTHORS, '$.firstName[0]' AS  "firstname" ,
     -> json_extract(AUTHORS, '$.lastName[0]' AS  "lastname" ,
     -> json_extract(AUTHORS, '$.genre[0]' AS  "genre"
     ->  FROM
     -> (
     ->  SELECT  id,json_extract(person_desc, '$.authors[0]' AS  "authors"  FROM  json
_test
     -> )  AS  T\G
*************************** 1. row ***************************
firstname:  "Isaac"
  lastname:  "Asimov"
     genre:  "sciencefiction"
1 row  in  set  (0.00 sec)


我们进一步来演示把authors 这个KEY对应的所有对象删掉。

1
2
3
4
mysql>  UPDATE  json_test
     ->  SET  person_desc = json_remove(person_desc, '$.authors' )\G
Query OK, 1 row affected (0.01 sec)
Rows  matched: 1  Changed: 1  Warnings: 0

查找下对应的KEY,发现已经被删除掉了。

1
2
3
4
5
mysql>  SELECT  json_contains_path(person_desc, 'all' , '$.authors' as  authors_exist
FROM  json_test\G
*************************** 1. row ***************************
authors_exists: 0
1 row  in  set  (0.00 sec)



总结下, 虽然MySQL5.7 开始支持JSON数据类型,但是我建议如果要使用的话,最好是把这样的值取出来,然后在应用程序段来计算,毕竟数据库是用来处理简单数据的。




本文转自 david_yeung 51CTO博客,原文链接:http://blog.51cto.com/yueliangdao0608/1711454,如需转载请自行联系原作者

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
344
分享
相关文章
【YashanDB知识库】MySQL迁移至崖山char类型数据自动补空格问题
**简介**:在MySQL迁移到崖山环境时,若字段类型为char(2),而应用存储的数据仅为'0'或'1',查询时崖山会自动补空格。原因是mysql的sql_mode可能启用了PAD_CHAR_TO_FULL_LENGTH模式,导致保留CHAR类型尾随空格。解决方法是与应用确认数据需求,可将崖山环境中的char类型改为varchar类型以规避补空格问题,适用于所有版本。
【YashanDB知识库】崖山BIT类型对MYSQL兼容问题
【YashanDB知识库】崖山BIT类型对MYSQL兼容问题
MySQL索引有哪些类型?
● 普通索引:最基本的索引,没有任何限制。 ● 唯一索引:索引列的值必须唯一,但可以有空值。可以创建组合索引,则列值的组合必须唯一。 ● 主键索引:是特殊的唯一索引,不可以有空值,且表中只存在一个该值。 ● 组合索引:多列值组成一个索引,用于组合搜索,效率高于索引合并。 ● 全文索引:对文本的内容进行分词,进行搜索。
mysql bit对gorm使用何种类型?
在GORM中使用MySQL的BIT类型时,通常使用 `bool`类型来处理BIT(1),使用 `[]byte`类型来处理BIT(N)(N > 1)。通过正确的类型映射和位操作,可以高效地处理位字段数据。确保在定义结构体字段时,明确指定字段类型,以便GORM能够正确地处理数据库交互。
72 18
【YashanDB 知识库】MySQL 迁移至崖山 char 类型数据自动补空格问题
问题分类】功能使用 【关键字】char,char(1) 【问题描述】MySQL 迁移至崖山环境,字段类型源端和目标端都为 char(2),但应用存储的数据为'0'、'1',此时崖山查询该表字段时会自动补充空格 【问题原因分析】mysql 有 sql_mode 控制,检查是否启用了 PAD_CHAR_TO_FULL_LENGTH SQL 模式。如果启用了这个模式,MySQL 才会保留 CHAR 类型字段的尾随空格,默认没有启动。 #查看sql_mode mysql> SHOW VARIABLES LIKE 'sql_mode'; 【解决/规避方法】与应用确认存储的数据,正确定义数据
mysql怎么查询longblob类型数据的大小
通过本文的介绍,希望您能深入理解如何查询MySQL中 `LONG BLOB`类型数据的大小,并结合优化技术提升查询性能,以满足实际业务需求。
266 6
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
100 4
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
108 8
数据集学习笔记(二): 转换不同类型的数据集用于模型训练(XML、VOC、YOLO、COCO、JSON、PNG)
本文详细介绍了不同数据集格式之间的转换方法,包括YOLO、VOC、COCO、JSON、TXT和PNG等格式,以及如何可视化验证数据集。
1126 1
数据集学习笔记(二): 转换不同类型的数据集用于模型训练(XML、VOC、YOLO、COCO、JSON、PNG)
用dbeaver创建一个enum类型,并讲述一部分,mysql的enum类型的知识
这篇文章介绍了如何在DBeaver中创建MySQL表的枚举(ENUM)字段,并探讨了MySQL中ENUM类型的一些行为特点,例如ENUM值的默认排序和在插入重复值时的表现。
130 1
用dbeaver创建一个enum类型,并讲述一部分,mysql的enum类型的知识
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等