MySQL 5.7新支持--------Json类型实战

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介:

1. 背景

  * 在MySQL 5.7.8中,MySQL支持由RFC 7159定义的本地JSON数据类型,它支持对JSON(JavaScript对象标记)文档中的数据进行有效访问.

  * MySQL会对DML JSON数据自动验证。无效的DML JSON数据操作会产生错误.

   * 优化的存储格式。存储在JSON列中的JSON文档转换为一种内部格式,允许对Json元素进行快速读取访问.

   * MySQL Json类型支持建立索引增加查询性能提升.


2. Json类型所需的存储空间和值范围

类型 占用字节 最大长度
Json 数据长度 + 4 bytes
4G


3. Json相关函数操作

   * JSON_OBJECT(string1, string2...) 创建 key-value 类型 Json 对象

1
2
3
4
5
6
7
mysql> SELECT JSON_OBJECT( 'k1' 'v1' 'k2' 'v2' );
+-------------------------------------+
| JSON_OBJECT( 'k1' 'v1' 'k2' 'v2' ) |
+-------------------------------------+
| { "k1" "v1" "k2" "v2" }            |
+-------------------------------------+
1 row  in  set  (0.01 sec)


   * JSON_ARRAY(string1, string2...) 创建一个 Json 数组

1
2
3
4
5
6
7
mysql> SELECT JSON_ARRAY( 'a' 'b' 'c' 'd' );
+--------------------------------+
| JSON_ARRAY( 'a' 'b' 'c' 'd' ) |
+--------------------------------+
| [ "a" "b" "c" "d" ]           |
+--------------------------------+
1 row  in  set  (0.00 sec)


   * JSON_TYPE(object) 判断并显示数据类型 [ 值非法会报错显示 ]

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
mysql>  SELECT JSON_TYPE( '"lisea"' );
+----------------------+
| JSON_TYPE( '"lisea"' ) |
+----------------------+
| STRING               |
+----------------------+
1 row  in  set  (0.01 sec)
 
mysql> SELECT JSON_TYPE( '["a", "b", 1]' );
+----------------------------+
| JSON_TYPE( '["a", "b", 1]' ) |
+----------------------------+
| ARRAY                      |
+----------------------------+
1 row  in  set  (0.01 sec)
 
mysql> SELECT JSON_TYPE( '1' );
+----------------+
| JSON_TYPE( '1' ) |
+----------------+
| INTEGER        |
+----------------+
1 row  in  set  (0.00 sec)
 
mysql> SELECT JSON_TYPE( '{"k1":"v1", "k2":"v2"}' );
+-------------------------------------+
| JSON_TYPE( '{"k1":"v1", "k2":"v2"}' ) |
+-------------------------------------+
| OBJECT                              |
+-------------------------------------+
1 row  in  set  (0.00 sec)


   * JSON_MERGE(doc1,doc2....) 合并多个Json对象

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> SELECT JSON_MERGE( '{"k1":"v1"}' , '{ "k2":"v2"}' );
+------------------------------------------+
| JSON_MERGE( '{"k1":"v1"}' , '{ "k2":"v2"}' ) |
+------------------------------------------+
| { "k1" "v1" "k2" "v2" }                 |
+------------------------------------------+
1 row  in  set  (0.04 sec)
 
mysql> SELECT JSON_MERGE( '["k1","k2"]' , '{ "k3":"v3"}' );
+------------------------------------------+
| JSON_MERGE( '["k1","k2"]' , '{ "k3":"v3"}' ) |
+------------------------------------------+
| [ "k1" "k2" , { "k3" "v3" }]               |
+------------------------------------------+
1 row  in  set  (0.00 sec)


   * JSON_EXTRACT(object, key) 通过Json key方式获取Val值

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> SELECT JSON_EXTRACT( '{"k1":"v1","k2":"v2"}' '$.k1' );
+-----------------------------------------------+
| JSON_EXTRACT( '{"k1":"v1","k2":"v2"}' '$.k1' ) |
+-----------------------------------------------+
"v1"                                           |
+-----------------------------------------------+
1 row  in  set  (0.01 sec)
 
mysql> SELECT JSON_EXTRACT( '{"k1":"v1","k2":"v2"}' '$.*' );
+----------------------------------------------+
| JSON_EXTRACT( '{"k1":"v1","k2":"v2"}' '$.*' ) |
+----------------------------------------------+
| [ "v1" "v2" ]                                 |
+----------------------------------------------+
1 row  in  set  (0.00 sec)


   * JSON_SET(object, key, val, key, val....) 通过key修改val值

1
2
3
4
5
6
7
mysql> SELECT JSON_SET( '{"k1":"v1","k2":"v2"}' '$.k1' 'lisea' '$.k2' 'hello' );
+---------------------------------------------------------------------+
| JSON_SET( '{"k1":"v1","k2":"v2"}' '$.k1' 'lisea' '$.k2' 'hello' ) |
+---------------------------------------------------------------------+
| { "k1" "lisea" "k2" "hello" }                                      |
+---------------------------------------------------------------------+
1 row  in  set  (0.00 sec)


   * JSON_INSERT(object, key, val)添加新值到对象中,如果key已存在,不替换val

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> SELECT JSON_INSERT( '{"k1":"v1","k2":"v2"}' '$.k1' 'hello' );
+-------------------------------------------------------+
| JSON_INSERT( '{"k1":"v1","k2":"v2"}' '$.k1' 'hello' ) |
+-------------------------------------------------------+
| { "k1" "v1" "k2" "v2" }                              |
+-------------------------------------------------------+
1 row  in  set  (0.03 sec)
 
mysql> SELECT JSON_INSERT( '{"k1":"v1","k2":"v2"}' '$.k3' 'v3' );
+----------------------------------------------------+
| JSON_INSERT( '{"k1":"v1","k2":"v2"}' '$.k3' 'v3' ) |
+----------------------------------------------------+
| { "k1" "v1" "k2" "v2" "k3" "v3" }               |
+----------------------------------------------------+
1 row  in  set  (0.02 sec)


   * JSON_REPLACE() 替换现有的值并忽略新的值

1
2
3
4
5
6
7
mysql> SELECT JSON_REPLACE( '{"k1":"v1","k2":"v2"}' '$.k1' 'hello' '$.k3' 'v3' );
+----------------------------------------------------------------------+
| JSON_REPLACE( '{"k1":"v1","k2":"v2"}' '$.k1' 'hello' '$.k3' 'v3' ) |
+----------------------------------------------------------------------+
| { "k1" "hello" "k2" "v2" }                                          |
+----------------------------------------------------------------------+
1 row  in  set  (0.01 sec)


   * JSON_REMOVE() 通过key移除

1
2
3
4
5
6
7
mysql> SELECT JSON_REMOVE( '{"k1":"v1","k2":"v2"}' '$.k1' );
+----------------------------------------------+
| JSON_REMOVE( '{"k1":"v1","k2":"v2"}' '$.k1' ) |
+----------------------------------------------+
| { "k2" "v2" }                                 |
+----------------------------------------------+
1 row  in  set  (0.00 sec)


   * JSON_KEYS() 获取所有key

1
2
3
4
5
6
7
mysql> SELECT JSON_KEYS( '{"k1":"v1","k2":"v2"}' );
+------------------------------------+
| JSON_KEYS( '{"k1":"v1","k2":"v2"}' ) |
+------------------------------------+
| [ "k1" "k2" ]                       |
+------------------------------------+
1 row  in  set  (0.03 sec)


   * JSON_UNQUOTE() 去掉值的引号

1
2
3
4
5
6
7
mysql> SELECT JSON_UNQUOTE( '"hello"' );
+-------------------------+
| JSON_UNQUOTE( '"hello"' ) |
+-------------------------+
| hello                   |
+-------------------------+
1 row  in  set  (0.01 sec)


   * JSON_DEPTH() 获取Json对象的深度

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> SELECT JSON_DEPTH( '{"k1":"v1","k2":"v2"}' );
+-------------------------------------+
| JSON_DEPTH( '{"k1":"v1","k2":"v2"}' ) |
+-------------------------------------+
|                                   2 |
+-------------------------------------+
1 row  in  set  (0.00 sec)
 
mysql> SELECT JSON_DEPTH( '{}' );
+------------------+
| JSON_DEPTH( '{}' ) |
+------------------+
|                1 |
+------------------+
1 row  in  set  (0.01 sec)


   * JSON_VALID() 判断是否为有效的json格式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> SELECT JSON_VALID( '{"k1":"v1"}' );
+---------------------------+
| JSON_VALID( '{"k1":"v1"}' ) |
+---------------------------+
|                         1 |
+---------------------------+
1 row  in  set  (0.00 sec)
 
mysql> SELECT JSON_VALID( '{"k1":"v1"' );
+--------------------------+
| JSON_VALID( '{"k1":"v1"' ) |
+--------------------------+
|                        0 |
+--------------------------+
1 row  in  set  (0.00 sec)


   * JSON_LENGTH() 获取指定路径下的长度

      长度的计算规则:

            标量的长度为1

            json array的长度为元素的个数

            json object的长度为key的个数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> SELECT JSON_LENGTH( '[1, 2, 3]' );
+--------------------------+
| JSON_LENGTH( '[1, 2, 3]' ) |
+--------------------------+
|                        3 |
+--------------------------+
1 row  in  set  (0.00 sec)
 
mysql> SELECT JSON_LENGTH( '{"k1":"v1", "k2":"v2"}' );                                                            
+---------------------------------------+
| JSON_LENGTH( '{"k1":"v1", "k2":"v2"}' ) |
+---------------------------------------+
|                                     2 |
+---------------------------------------+
1 row  in  set  (0.00 sec)


   * JSON_SEARCH(json_doc, one_or_all, search_str[, escape_char[, path] ...])  

   查询包含指定字符串的paths,并作为一个json array返回 

   one_or_all:"one"表示查询到一个即返回;"all"表示查询所有。

   search_str:要查询的字符串。 可以用LIKE里的'%'或‘_’匹配。

   path:在指定path下查。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql> SELECT JSON_SEARCH( '{"k1":"v1", "k2":"v2", "k3":"v2"}' 'one' 'v2%' );
+----------------------------------------------------------------+
| JSON_SEARCH( '{"k1":"v1", "k2":"v2", "k3":"v2"}' 'one' 'v2%' ) |
+----------------------------------------------------------------+
"$.k2"                                                          |
+----------------------------------------------------------------+
1 row  in  set  (0.00 sec)
 
mysql> SELECT JSON_SEARCH( '{"k1":"v1", "k2":"v2", "k3":"v2"}' 'all' 'v2%' );
+----------------------------------------------------------------+
| JSON_SEARCH( '{"k1":"v1", "k2":"v2", "k3":"v2"}' 'all' 'v2%' ) |
+----------------------------------------------------------------+
| [ "$.k2" "$.k3" ]                                               |
+----------------------------------------------------------------+
1 row  in  set  (0.01 sec)


4. 总结


以需求驱动技术,技术本身没有优略之分,只有业务之分。




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




相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
18天前
|
SQL 存储 关系型数据库
不允许你不知道的 MySQL 优化实战(三)
不允许你不知道的 MySQL 优化实战(三)
25 1
|
6天前
|
存储 关系型数据库 MySQL
9.2.5.2 【MySQL】XDES 类型
9.2.5.2 【MySQL】XDES 类型
10 0
9.2.5.2 【MySQL】XDES 类型
|
6天前
|
存储 关系型数据库 MySQL
MySQL字段的字符类型该如何选择?千万数据下varchar和char性能竟然相差30%🚀
本篇文章来讨论MySQL字段的字符类型选择并深入实践char与varchar类型的区别以及在千万数据下的性能测试
MySQL字段的字符类型该如何选择?千万数据下varchar和char性能竟然相差30%🚀
|
13天前
|
缓存 关系型数据库 MySQL
MySQL数据库性能优化实战
【4月更文挑战第30天】本文探讨了MySQL性能优化实战技巧,包括硬件与配置优化(如使用SSD、增加内存和调整配置参数)、索引优化(创建合适索引、使用复合索引及定期维护)、查询优化(避免全表扫描、减少JOIN和使用LIMIT)、分区与分片(表分区和数据库分片),以及使用缓存、定期清理数据库和监控诊断。通过这些方法,可以提升数据库性能和响应速度。
|
13天前
|
SQL DataWorks 关系型数据库
DataWorks操作报错合集之DataWorks在同步mysql时报错Code:[Framework-02],mysql里面有个json类型字段,是什么原因导致的
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
30 0
|
13天前
|
关系型数据库 MySQL Java
Java时间转换为MySQL中的INT类型时间戳
Java时间转换为MySQL中的INT类型时间戳
|
13天前
|
分布式计算 DataWorks 关系型数据库
DataWorks产品使用合集之在DataWorks中,使用JSON解析函数将MySQL表中的字段解析成多个字段将这些字段写入到ODPS(MaxCompute)中如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
27 3
|
13天前
|
存储 JSON DataWorks
DataWorks产品使用合集之DataWorks将 MongoDB 中的数组类型写入到 DataWorks 的单个字段时,表示为字符串格式而非 JSON 格式如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
26 3
|
15天前
|
存储 关系型数据库 MySQL
MySQL数据库实战:从入门到精通
本文介绍了MySQL的使用和优化,适合Web开发者阅读。首先,确保安装并配置好MySQL,熟悉SQL基础。接着,通过命令行客户端连接数据库,执行创建、查询、添加、修改和删除数据等操作。学习数据类型并创建表存储数据。最后,探讨了数据库优化,包括查询优化和索引使用,以提升性能。
26 2
|
17天前
|
安全 关系型数据库 MySQL
node实战——后端koa结合jwt连接mysql实现权限登录(node后端就业储备知识)
node实战——后端koa结合jwt连接mysql实现权限登录(node后端就业储备知识)
23 3

推荐镜像

更多