加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 移动互联 > 正文

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

发布时间:2019-07-19 00:19:42 所属栏目:移动互联 来源:波波说运维
导读:概述 在MySQL数据库中,直到5.7这个版本,开始引入JSON数据范例,在此之前假如想在表中生涯JSON名目范例的数据,则必要依赖varchar可能text之类的数据范例,假如在低于5.7版本的数据库中行使了JSON范例来建表,显然是不会乐成的。 怎样行使JSON范例 1、建

概述

在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

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读