当前位置 : IT培训网 > IT培训 > 新闻资讯 > 零基础学习MySQL数据库 快速掌握JSON类型知识

零基础学习MySQL数据库 快速掌握JSON类型知识

时间:2019-07-17 10:58:59  来源:编程网  作者:IT培训网  已有:名学员访问该课程
标签(Tag):   MySQL数据库(10)
其实,没有JSON数据类型的支持,我们一样可以通过varchar类型或者text等类型来保存这一格式的数据,但是,为什么还要专门增加这一数据格式的支持呢?其中肯定有较varchar或者text来存储此类型更优越的地方。

网站的载体是什么呢,无疑就是服务器了,可是网站的数据存放在哪里呢?如今的网页不比以前,只要做一个静态的页面即可,在大数据下,动态的页面流行起来,实时更新,实时浏览不同的页面是用户的需求,这样就需要从后台调用数据,而这些数据就有一个载体,那就是数据库,一个用来存放网站内容的容器-mysql,那么如何学习它呢,怎么样掌握它呢?

详解MySQL数据库JSON类型--用法、意义、内置函数!让每个学习数据库的学子都可以顺利学习MySQL数据库?

作者:波波说运维

来源:今日头条

概述

在MySQL数据库中,直到5.7这个版本,开始引入JSON数据类型,在此之前如果想在表中保存JSON格式类型的数据,则需要依靠varchar或者text之类的数据类型,如果在低于5.7版本的数据库中使用了JSON类型来建表,显然是不会成功的。

零基础学习MySQL数据库 快速掌握JSON类型知识_www.itpxw.cn

如何使用JSON类型

1、建表

在MySQL中创建具有JSON数据列的表,其实和数据类型没有太大区别,具体举例如下:

CREATE TABLE tab_base_info (

id BIGINT NOT NULL PRIMARY KEY auto_increment,

content json

);

2、新增数据

插入一条语句,注意看JSON数据列的内容:

INSERT INTO tab_base_info(content) VALUES ('{"author": "HWB", "toutiao": "http://www.itpxw.cn/uisj/web/20198616.html"}');

零基础学习MySQL数据库 快速掌握JSON类型知识_www.itpxw.cn

这里需要提醒的是:

JSON列存储的数据要么是NULL,要么必须是JSON格式数据,否则会报错。

JSON数据类型是没有默认值的(声明时"DEFAULT NULL")。

JSON数据类型意义

其实,没有JSON数据类型的支持,我们一样可以通过varchar类型或者text等类型来保存这一格式的数据,但是,为什么还要专门增加这一数据格式的支持呢?其中肯定有较varchar或者text来存储此类型更优越的地方。

保证了JSON数据类型的强校验,JSON数据列会自动校验存入此列的内容是否符合JSON格式,非正常格式则报错,而varchar类型和text等类型本身是不存在这种机制的。

MySQL同时提供了一组操作JSON类型数据的内置函数。

更优化的存储格式,存储在JSON列中的JSON数据会被转成内部特定的存储格式,允许快速读取。

可以基于JSON格式的特征支持修改特定的键值。(即不需要把整条内容拿出来放到程序中遍历然后寻找替换再塞回去,MySQL内置的函数允许你通过一条SQL语句就能搞定)

MySQL关于JSON的内置函数

MySQL关于JSON数据格式的操作提供了很多高效率的内置函数,我们可以从MySQL官网上找到很详细的介绍和使用说明,下面贴一张JSON函数的指南:

零基础学习MySQL数据库 快速掌握JSON类型知识_www.itpxw.cn

其实从JSON功能介绍的主页也可以看到,这些内置函数支持我们创建、查找、替换和返回值等相关的操作,像我们替换指定内容的操作就可以使用JSON_REPLACE()这个函数,不过最后实现通过纯SQL语句执行最终的内容替换,还需要通过执行UPDATE语句,比如:

UPDATE tab_base_info SET content = json_replace(content, '$.author', "xiaoming") WHERE id = 1;

零基础学习MySQL数据库 快速掌握JSON类型知识_www.itpxw.cn

其中“$.***”表示找到JSON内容中匹配的修改字段。

篇幅有限,这里主要介绍一下json的一些概念,后面会介绍下涉及到json类型的具体用法,感兴趣的朋友可以关注一下~

顶一下
(0)
0%
踩一下
(0)
0%

IT培训0元试听 每期开班座位有限.0元试听抢座开始! IT培训0元试听

  • 姓名 : *
  • 电话 : *
  • QQ : *
  • 留言 :
  • 验证码 : 看不清?点击更换请输入正确的验证码

在线咨询在线咨询

温馨提示 : 请保持手机畅通,咨询老师为您
提供专属一对一报名服务。

------分隔线----------------------------
------分隔线----------------------------

推荐内容