前言(废话)

昨天抽了点时间在网上搜列了一个开源项目,项目挺完整的,前后台分离还带有微信小程序,我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 TABLEtab_base_info (2 id BIGINT NOT NULL PRIMARY KEYauto_increment,3 content json4 );

新增数据

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

1 INSERT INTOtab_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 UPDATEtab_base_info2 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

json mysql 字段 默认值_MySQL中的JSON类型相关推荐

  1. json mysql 字段 默认值_MySQL新增JSON类型字段的使用总结

    最近刚好用到了MySQL的JSON函数做了一些数据处理相关的工作,顺便记录总结一下相关知识点和用法. MySQL从5.7.8开始支持原生JSON数据类型,以JSON类型存储json格式的数据,比字符串 ...

  2. json mysql 字段 默认值_mysql json字段

    查看插入的数据 mysql> SELECT * FROM lnmp; +----+------------------------------+-----------+ | id | categ ...

  3. MySQL 字段默认值该如何设置

    MySQL 字段默认值该如何设置 前言: 在 MySQL 中,我们可以为表字段设置默认值,在表中插入一条新记录时,如果没有为某个字段赋值,系统就会自动为这个字段插入默认值.关于默认值,有些知识还是需要 ...

  4. mysql字段默认值不生效的问题解决(上)

    mysql字段默认值不生效的问题解决(上) 参考文章: (1)mysql字段默认值不生效的问题解决(上) (2)https://www.cnblogs.com/yuhuameng/p/10703931 ...

  5. mysql数据类型默认值_MySQL数据类型 - 数据类型默认值

    数据类型默认值 数据类型规范可以有显式或隐式的默认值. 数据类型规范中的DEFAULT值子句显式指示列的默认值.示例: SERIAL DEFAULT VALUE是一种特殊情况.在整数列的定义中,它是N ...

  6. mysql修改字段默认值_MySQL增删改查操作

    增删改查操作 查询表中的所有的记录:select from 表名(xs) 创建数据库:create database if not exists xsgl; 8.2创建表:cerate table i ...

  7. sqlyog怎么设置默认值_mysql 中怎样设置默认值为系统日期

    -- 方法一: 由于MySQL目前字段的默认值不支持函数,所以以create_time datetime default now() 的形式设置默认值是不可能的.代替的方案是使用TIMESTAMP类型 ...

  8. mysql intt默认值_MySQL如何处理隐式默认值

    有同学说遇到了主从不一致的问题. 大概情况是,从库是用mysqldump导出导入数据的方式创建的.创建成功后,在用mysqldump验证主从的表结构是否一致的时候,发现有些表定义不一致: 从他的比较结 ...

  9. mysql字段默认值

    mysql数据库填入数据时遇到的一个问题,使用getHibernateTemplate().save()实例化,没有给出name字段的值,填入数据时通过mysqlworkbench查看发现name字段 ...

最新文章

  1. 【优秀博文】知乎服务化的实践与思考
  2. exception: access violation reading 0xFFFFFFFFFFFFFFFF
  3. 蓝牙连接不上车要hfp_蓝牙耳机的音质由什么因素决定?价格高的蓝牙耳机音质一定好吗?...
  4. python的优缺点有哪些-python语言的优缺点
  5. 【Linux】一步一步学Linux——dpkg-query命令(271)
  6. BZOJ3448 : [Usaco2014 Feb]Auto-complete
  7. linux中PATH变量-详细介绍
  8. VSCode 实时预览HTML网页效果 - Live Server插件
  9. erlang 程序设计书中的错误
  10. 迷你MVVM框架 avalonjs 学习教程6、插入移除处理
  11. SwitchHost无法切换环境
  12. 支付宝当面付_没有营业执照也能开支付宝当面付啦
  13. 计算机屏幕抖动怎么办,电脑显示屏画面颤抖是怎么回事?
  14. 统计元音(函数专题)
  15. python安装pip之后镜像源配置
  16. Python-TypeError:takes no arguments
  17. win10开机任务栏转圈假死怎么办
  18. 微信小程序滑动scroll-view
  19. 天河服务器维修,天河云服务器升级
  20. 基于Caret和RandomForest包进行随机森林分析的一般步骤 (1)

热门文章

  1. mknod创建设备(加载新的设备驱动时候,通常会用到此命令)
  2. MySQL高性能优化规范建议
  3. 智能驾驶继续突破,国内国外技术进入深水区
  4. java 字符串过长_idea java常量字符串过长解决办法
  5. rpm卸载mysql和php_CentOS 6.5 卸载mysql和php
  6. python xml解析dom_如何解析python中表示xml.dom.minidom节点的字符串?
  7. php微信小程序物流进度推送,微信小程序 消息推送php服务器验证实例详解
  8. #模拟触手机屏幕_从操作系统的改变谈手机设计进化,单手并不是最终的便捷...
  9. 为什么vs数据库中文显示问号_在vs2008中注册页面中的中文字符写入数据库的后中文会变成问号...
  10. idea 代码自动补全快捷键