当前位置: 移动技术网 > IT编程>数据库>Mysql > MySQL中的JSON类型

MySQL中的JSON类型

2019年07月12日  | 移动技术网IT编程  | 我要评论

前言(废话)

昨天抽了点时间在网上搜列了一个开源项目,项目挺完整的,前后台分离还带有微信小程序,我clone下代码,经过一番倒腾,嘿~还真就跑起来了。在这个过程中,体验了一把vue项目工程细节,因为之前没有接触过这一块,所以还是花费了点时间,好在开源项目的qq群里楼主帮忙看了一下,才得以顺利往后进行。后来也有很多网友向楼主提问,也抛出了一些问题,其中有个问题到引起了我的注意。

有个小伙伴执行sql的时候报错了,以为项目中给的sql脚本不全,但是在群里他并没有给出报错细节的截图,楼主后来也就提示了他一句mysql版本需要在5.7以上,但是后面就没有更多消息了。

今天早上我还在上班路上,群里的小伙伴就私信我,说能否帮他看下数据库的问题。等我到了公司再回复他的时候,他告诉我说数据库问题已经解决了,我追问了一下细节,原来是开源项目中的数据库建表语句中包含json类型字段,导致了他批量执行sql脚本不成功。其实这样的问题,在执行脚本的时候遇到错误是有日志的,详细看下日志应该明了。

我其实是没有注意到这个细节的,因为我前天安装的数据库就直接上了8.0,屏蔽了这个问题,但是,mysql数据库现在支持json类型,挺新奇的,因为之前没有用过,并不熟悉,所以这一次,让我逮到个了解它的机会。

关于mysql的json类型

json估计大家伙都熟悉了,我就不再介绍这方面内容。其实在mysql数据库中,也直到5.7这个版本,才开始引入json数据类型,在此之前如果想在表中保存json格式类型的数据,则需要依靠varchar或者text之类的数据类型,如果在低于5.7版本的数据库中使用了json类型来建表,显然是不会成功的。

(截图为mysql官网文档)

如何使用json类型

建表

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

1 create table tab_base_info (
2     id bigint not null primary key auto_increment,
3     content json
4 );

新增数据

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

1 insert into tab_base_info (content)
2 values
3 (
4     '{"author": "captain&d", "blog": "https://www.cnblogs.com/captainad"}'
5 );

这里需要提醒的是:

  • 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_replace()这个函数,不过最后实现通过纯sql语句执行最终的内容替换,你还需要通过执行update语句,比如:

1 update tab_base_info 
2 set content = json_replace(content, '$.author', "tom") 
3 where id = 1;

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

更多关于这些内置函数的用法,大家都可以到官网(链接请查看本文参考资料)的文档上去查阅,写的十分详细而且还有举例。

参考资料:

1、https://zhuanlan.zhihu.com/p/31823258

2、https://dev.mysql.com/doc/refman/5.7/en/json-functions.html

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网