资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

MySQL数据库JSON类型的用法、意义、内置函数

这篇文章主要讲解了“MySQL数据库JSON类型的用法、意义、内置函数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL数据库JSON类型的用法、意义、内置函数”吧!

公司主营业务:成都网站设计、成都网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出武强免费做网站回馈大家。

概述

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

MySQL数据库JSON类型的用法、意义、内置函数

如何使用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": "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语句,比如:

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

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

感谢各位的阅读,以上就是“MySQL数据库JSON类型的用法、意义、内置函数”的内容了,经过本文的学习后,相信大家对MySQL数据库JSON类型的用法、意义、内置函数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


文章名称:MySQL数据库JSON类型的用法、意义、内置函数
网页链接:http://www.cdkjz.cn/article/jejiec.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220