前言

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

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

下面一起来实际操作一下。

创建带有 JSON 字段的表

比如一个‘文章'表,字段包括

id、标题 title、标签 tags

一篇文章会有多个标签,tags 就可以设为 JSON 类型

建表语句如下:

1
2
3
4
5
6
7
8
9
10
11
CREATE TABLE `article` (
 
 `id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT,
 
`title` varchar(200) NOT NULL,
 
 `tags` json DEFAULT NULL,
 
PRIMARY KEY (`id`)
 
) ENGINE=InnoDB;

插入数据

插入一条带有 JSON 内容的数据,执行 insert 语句:

1
2
3
4
5
6
7
8
9
INSERT INTO `article` (`title`, `tags`)
 
VALUES (
 
'体验 Mysql JSON',
 
'["Mysql", "Database"]'
 
);

这里插入的是一个 JOSN 数组 [“Mysql”, “Database”]

查询 article 表中的所有内容,可以看到新插入的这条数据

查询

使用 JSON 函数做两个简单的查询

1.查找带有标签”Mysql”的所有文章

1
2
3
SELECT * FROM `article`
 
WHERE JSON_CONTAINS(tags, '["Mysql"]');

2.查找标签中以”Data”开头的文章

1
2
3
SELECT * FROM `article`
 
WHERE JSON_SEARCH(tags, 'one', 'Data%') IS NOT NULL;

JSON_SEARCH 函数中3个参数的含义:

1.要查找的文档

2.查找的范围,有两个选项,'one' 查找第一个符合条件的,'all'查找所有符合条件的

3.查找的条件

JSON Path

JSON Path用来定位文档中的目标字段,例如

1
2
3
4
5
6
7
SELECT JSON_EXTRACT(
 
'{"id": 1, "name": "mysql"}',
 
'$.name'
 
);

结果为:mysql

JSON_EXTRACT() 是JSON提取函数,$.name 就是一个 JSON path,表示定位文档的 name 字段

JSON path 是以 $ 开头,下面看几个更多的示例

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
{
 
"num": 123,
 
"arr": [1, 2],
 
"obj": {
 
"a": 3,
 
"b": 4
 
}
 
}
 
$.num //结果:123
 
$.arr //结果:[1, 2]
 
$.arr[1] //结果:1
 
$.obj.a //结果:3
 
$**.b //结果:4

使用 JSON path 的查询示例

1
2
3
4
5
SELECT
 
tags->"$[0]" as 'tag'
 
FROM `article`;

更新数据

例如想给文章添加一个 “dev” tag,更新的条件是已经包含 “Mysql” 标签,并且还没有 “dev” 标签的数据

更新语句如下:

1
2
3
4
5
6
7
8
9
10
11
UPDATE `article`
 
SET tags = JSON_MERGE(tags, '["dev"]')
 
WHERE
 
JSON_SEARCH(tags, 'one', 'dev') IS NULL
 
AND
 
JSON_SEARCH(tags, 'one', 'Mysql') IS NOT NULL;

可以看到成功添加了 “dev” 标签

再比如想把 “Mysql” 这个标签更新为 “Mysql 5.7.13″,更新语句如下:

1
UPDATE `article` set tags = JSON_SET(tags, ‘$[0]', ‘Mysql 5.7.13') ;

上面体验了 JSON_MERGE 和 JSON_SET,用于修改JSON的函数还有很多,例如:

1
JSON_INSERT(doc, path, val[, path, val]…)

插入数据

1
JSON_REPLACE(doc, path, val[, path, val]…)

替换数据

1
JSON_ARRAY_APPEND(doc, path, val[, path, val]…)

向数组尾部追加数据

1
JSON_REMOVE(doc, path[, path]…)

从指定位置移除数据

通过初步的操作体验,感觉 Mysql 的 JSON 操作还是比较顺畅的,以后可以在mysql中使用文档结构确实很方便

新版的 Mysql 还提供了 Javascript 的控制台,类似 MongoDB 的 shell,也很方便,后面会总结出来。希望本文给大家在学习mysql的时候有所帮助,谢谢对脚本之家的支持。

Mysql中的JSON系列操作函数的更多相关文章

  1. JavaScript中常见的数组操作函数及用法

    JavaScript中常见的数组操作函数及用法 昨天写了个帖子,汇总了下常见的JavaScript中的字符串操作函数及用法.今天正好有时间,也去把JavaScript中常见的数组操作函数及用法总结一下 ...

  2. JavaScript中常见的字符串操作函数及用法

    JavaScript中常见的字符串操作函数及用法 最近几次参加前端实习生招聘的笔试,发现很多笔试题都会考到字符串的处理,比方说去哪儿网笔试题.淘宝的笔试题等.如果你经常参加笔试或者也是一个过来人,相信 ...

  3. 在MySQL中实现Rank高级排名函数【转】

    MySQL中没有Rank排名函数,当我们需要查询排名时,只能使用MySQL数据库中的基本查询语句来查询普通排名.尽管如此,可不要小瞧基础而简单的查询语句,我们可以利用其来达到Rank函数一样的高级排名 ...

  4. 关于mysql中存储json数据的读取问题

    在mysql中存储json数据,字段类型用text,java实体中用String接受. 返回前端时(我这里返回前端的是一个map),为了保证读取出的数据排序错乱问题,定义Map时要用LinkedHas ...

  5. 在MySQL中实现Rank高级排名函数

    MySQL中没有Rank排名函数,当我们需要查询排名时,只能使用MySQL数据库中的基本查询语句来查询普通排名.尽管如此,可不要小瞧基础而简单的查询语句,我们可以利用其来达到Rank函数一样的高级排名 ...

  6. (笔记)Linux内核中内存相关的操作函数

    linux内核中内存相关的操作函数 1.kmalloc()/kfree() static __always_inline void *kmalloc(size_t size, gfp_t flags) ...

  7. LoadRunner中常用的字符串操作函数

    LoadRunner中常用的字符串操作函数有:                strcpy(destination_string, source_string);               strc ...

  8. trim()函数 mysql中的强大字符串过滤函数

    mysql中功能强大的trim()函数. 去除两边空格: mysql> select trim(' hello world '); +-----------------------+ | tri ...

  9. 开发过程中 的一些 补充知识点 + 关于mysql中的日期和时间函数?

    参考: https://www.jb51.net/article/23966.htm https://yq.aliyun.com/articles/260389 mysql中的 日期格式是: HHHH ...

随机推荐

  1. java禁止实例化的工具类

    public class Q { /** * @param args */ public static void main(String[] args) { new Person() } } clas ...

  2. Linux下部署weblogic应用

    1.Linux下weblogic安装 2.Linux下设置weblogic监听服务器地址(默认为本机) 1).修改domain\config\config.xml文件 修改 <server> ...

  3. 如何去掉Json字符串中反斜杠

    做项目的时候,遇到了这样的问题,前台传来的Json字符串在实体类中不对应(无法转换为实体类),而且传来的数据项是跟着数据库中的表的变动而变动的(不能重写实体类). 前台Json字符串为: string ...

  4. 2017年上海金马五校程序设计竞赛:Problem E : Find Palindrome (字符串处理)

    Description Given a string S, which consists of lowercase characters, you need to find the longest p ...

  5. karma和jasmine的测试(包括angular测试)

    本篇博客主要就是针对现在日新月异的技术和快速开发,测试被很多人忽略,其实在开发中如何保证代码的质量以及逻辑的完整性,测试显得十分重要,本文就是负责karma+jasmine来测试. 1.搭建测试的环境 ...

  6. C++学习笔记之——内联函数,引用

    本文为原创作品,转载请注明出处 欢迎关注我的博客:http://blog.csdn.net/hit2015spring和http://www.cnblogs.com/xujianqing/ 作者:晨凫 ...

  7. LeetCode 4 Median of Two Sorted Array

    There  are two sorted arrays A and B of size m and n respectively. Find the median of the two sorted ...

  8. Linux中实现一个简单的进度条【转】

    转自:http://blog.csdn.net/yuehailin/article/details/53999288 说起进度条,其实大家常常见到,比如说你在下载视频或文件的时候,提示你当前下载进度的 ...

  9. Mac升级Vim

    Mac自带的vim版本过低,可以使用如下方式进行升级,说白了就是备份替换: 1. 使用port安装新的vim,安装目录在/opt/local sudo port install vim 2. 如果已经 ...

  10. junit单元测试+junit与Spring结合

    配置:右键要加入单元测试的工程,选择properties,然后选择java build path,选择add library,选择junit即可. 编写:右键要测试的class,new一个junit ...