json mysql 字段 默认值_MySQL中的JSON类型

本文介绍了MySQL从5.7版本开始引入的JSON数据类型,包括如何使用JSON类型创建表和插入数据,强调了JSON列的强校验和内置函数的优势,并列举了MySQL的JSON函数示例。

前言(废话)

昨天抽了点时间在网上搜列了一个开源项目,项目挺完整的,前后台分离还带有微信小程序,我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

<think>我们正在处理一个关于MySQL数据库的问题:如何为decimal字段类型设置或修改默认值。根据用户的问题,我们需要参考提供的引用内容。引用[2]中提到了如何为JSON类型设置默认值,使用DEFAULT关键字。引用[3]提到了decimal字段类型,但没有直接说明如何设置默认值。引用[4]中展示了如何获取字段默认值等信息,但没有直接说明如何设置。但是,我们知道在MySQL中,设置或修改字段默认值通常使用ALTERTABLE语句。对于decimal类型,设置默认值的方法与其他数值类型类似。具体步骤:1.如果是在创建表时设置默认值,可以在定义字段时使用DEFAULT关键字。2.如果是在已存在的表中修改字段默认值,可以使用ALTERTABLE语句修改字段默认值。根据引用[2]中的示例,设置默认值使用DEFAULT后跟一个值。对于decimal类型,我们需要指定一个十进制数值作为默认值。示例:创建表时设置:CREATETABLEexample(idINTPRIMARYKEY,amountDECIMAL(10,2)DEFAULT0.00);修改现有表的字段默认值:ALTERTABLEexampleALTERCOLUMNamountSETDEFAULT0.00;或者(在MySQL中也可以使用MODIFYCOLUMN):ALTERTABLEexampleMODIFYCOLUMNamountDECIMAL(10,2)DEFAULT0.00;注意:修改字段默认值不会影响已有的数据,只会影响后续插入的数据。另外,根据引用[3]中关于decimal的说明,decimal(M,D)中的M是总位数,D是小数位数。在设置默认值时,需要确保默认值符合定义的范围。因此,回答用户的问题:在MySQL中,可以通过以下两种方式为decimal字段设置或修改默认值:1.在创建表时,在字段定义中使用DEFAULT关键字指定默认值。2.在已有表中,使用ALTERTABLE语句,结合ALTERCOLUMN...SETDEFAULT或MODIFYCOLUMN来设置默认值。下面给出具体示例。</think>### 如何在 MySQL 中为 DECIMAL 字段设置或修改默认值MySQL 中为 `DECIMAL` 字段设置默认值需通过以下两种方式实现: #### 1. 创建表时设置默认值(推荐) 在 `CREATE TABLE` 语句中使用 `DEFAULT` 关键字: ```sql CREATE TABLE 表名 ( 字段名 DECIMAL(总位数, 小数位数) DEFAULT 默认值 ); ``` **示例**: 创建商品表,为价格字段设置默认值 0.00: ```sql CREATE TABLE products ( id INT AUTO_INCREMENT PRIMARY KEY, price DECIMAL(10, 2) DEFAULT 0.00 -- 总位数10,小数位2,默认值0.00 ); ``` #### 2. 修改已有表的默认值 使用 `ALTER TABLE` 修改字段定义: ```sql ALTER TABLE 表名 MODIFY COLUMN 字段名 DECIMAL(总位数, 小数位数) DEFAULT 新默认值; ``` **示例**: 将订单表的金额字段默认值改为 100.50: ```sql ALTER TABLE orders MODIFY COLUMN amount DECIMAL(12, 2) DEFAULT 100.50; ``` #### ⚠️ 注意事项: 1. **默认值格式** 必须使用数值格式(如 `99.99`),禁止字符串格式(如 `'99.99'`),否则报错[^3]。 2. **范围匹配** 默认值需符合字段定义的范围。例如 `DECIMAL(5,2)` 的默认值不能超过 `999.99`[^4]。 3. **删除默认值** 将默认值设为 `NULL`(需确保字段允许为空): ```sql ALTER TABLE 表名 ALTER COLUMN 字段名 DROP DEFAULT; ``` 4. **默认值约束** 修改默认值不会影响已有数据,仅作用于新插入的记录[^2]。 --- ### 相关问题 1. `DECIMAL(10,2)` 和 `FLOAT` 类型在存储金额时有何区别? 2. 如何为 MySQLJSON 类型字段设置默认值(如 `{"stock":0}`)[^2]? 3. 修改字段默认值时,如何避免影响现有数据的完整性? 4. 如何查询 MySQL 表结构中字段默认值定义(类似 SQL Server 的 `information_schema`)[^4]? [^1]: ENUM 类型因为只允许在集合中取得一个值,有点类似于单选项。在处理相互排拆的数据时容易让人理解,比如人类的性别。 [^2]: 在 MySQL 中,可以使用 JSON 类型,并使用 DEFAULT 关键字来设置默认值。 [^3]: 数据库存储负值,如果某列设置为zerofill,那它自动就unsigned。这个值要配合int,tinyint,smallint,midiumint等字段的宽度指示器来用。 [^4]: SQL Server 获取数据表结构字段名,数据类型默认值,长度,为空,说明。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值