|
|
51CTO旗下网站
|
|
移动端

详解MySQL数据库JSON类型:用法、意义、内置函数

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

作者:波波说运维来源:今日头条|2019-07-17 10:19

概述

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

详解MySQL数据库JSON类型--用法、意义、内置函数

如何使用JSON类型

1、建表

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

  1. CREATE TABLE tab_base_info ( 
  2.  id BIGINT NOT NULL PRIMARY KEY auto_increment, 
  3.  content json 
  4. ); 

2、新增数据

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

  1. INSERT INTO tab_base_info(content) VALUES ('{"author": "HWB", "toutiao": "https://www.toutiao.com/a6712764513814315528"}'); 
详解MySQL数据库JSON类型--用法、意义、内置函数

这里需要提醒的是:

  • 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类型--用法、意义、内置函数

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

  1. UPDATE tab_base_info SET content = json_replace(content, '$.author'"xiaoming"WHERE id = 1; 
详解MySQL数据库JSON类型--用法、意义、内置函数

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

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

【编辑推荐】

  1. 结构化SQL数据库与非结构化NOSQL数据库大比拼
  2. 我以为我对MySQL索引很了解,直到我遇到了阿里的面试官
  3. 浅谈MySQL主从数据库同步延迟问题解决方案
  4. MySQL实用语句收集
  5. 分享一份实用的MySQL数据库规范,值得收藏
【责任编辑:华轩 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

16招轻松掌握PPT技巧

16招轻松掌握PPT技巧

GET职场加薪技能
共16章 | 晒书包

289人订阅学习

20个局域网建设改造案例

20个局域网建设改造案例

网络搭建技巧
共20章 | 捷哥CCIE

645人订阅学习

WOT2019全球人工智能技术峰会

WOT2019全球人工智能技术峰会

通用技术、应用领域、企业赋能三大章节,13大技术专场,60+国内外一线人工智能精英大咖站台,分享人工智能的平台工具、算法模型、语音视觉等技术主题,助力人工智能落地。
共50章 | WOT峰会

0人订阅学习

读 书 +更多

超级网管员——网络管理

本书全面深入地介绍了在网络的日常管理中,网络管理员必须掌握的知识,包括系统基本管理、性能调优、故障恢复、域控制器管理、存储资源管理...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO播客