mysql设置text字段为not null,并且没有默认值,插入报错:doesn't have a default value
一、问题描述
在往数据库写入数据的时候,报错:
'字段名' doesn't have a default value
本来这个错误是经常见到的,无非就是字段没有设置默认值造成的。奇怪的是,我这边报错的字段,其类型是text类型。众所周知的,text类型是不能有默认值的。如此一来就有了矛盾,text类型的字段明明不能有默认值,那么为什么还会给我报错,提示缺少默认值呢?
二、问题所在
1、查看字段类型
通过phpmyadmin查看数据表的字段结构,发现text字段在创建的时候,语法为:
//创建字段abstract为text类型,默认为not null
ALTER TABLE `表名` ADD COLUMN `abstract` text not null after `content`;
这个创建语句乍一看没有问题,但是如果text类型既没有默认值,也不能为null的话,那么插入的时候,肯定是会出现问题的。
2、解决方案
按照上面的推测逻辑,重新修改字段属性:
//这里修改abstart字段的类型为text类型,去掉了not null
ALTER TABLE `表名` modify COLUMN `abstract` text;
然后进行测试,发现写入数据成功。此时查看phpmyadmin的数据表结构,发现此时字段的默认值为null了。果然是not null的问题,问题是,创建数据表的时候,尽量设置字段为not null已经成为共识。。虽然解决了问题,但博主还是不太理解原理是什么。
关于mysql默认值和设置not null的问题,参考博客:
关于mysql设置varchar 字段的默认值’'和null的区别,以及varchar和char的区别
三、为什么会报错
1、第一个原因
通过一顿百度,终于在百度知道上看到这句话:
如果是not null的话,那你就必须插入一个值,你不插入值的话,就会调用默认值。 如果这两个都没有的话,就会报错了。
这个意思就和咱们最开始推测的差不多,字段类型既是 not null,而且还没默认值,那么在写入数据的时候肯定是有问题的。就像我们平时看到的,在创建字段并且不设置默认值的时候,mysql都会默认给字段加上默认值null。
2、第二个原因
这个原因就是数据库的严格模式的问题。在mysql 5.7之后,数据库默认都是采用严格模式。
关于严格模式的解释:
mysql给字段设置默认值,以及mysql的严格模式
关于严格模式这个,我并没有测试,个人感觉还是建表时候不够严谨造成的问题。关于设置字段默认值和设置not null方面不熟悉造成的。
四、总结
**1、**如果字段为int 或者varchar类型,那么要设置字段类型为 not null 并且设置default
**2、**如果字段为text,则既不需要设置not null,也不需要手动设置default 的值
**3、**关于text字段不能有默认值的问题,这个只针对于手动增加的default属性,如果创建字段不设置default的话,mysql会默认加上一个默认值Null
end
mysql设置text字段为not null,并且没有默认值,插入报错:doesn't have a default value相关推荐
- MySQL语句增加字段,修改字段名,修改类型,修改默认值
增加字段: alter table 表名 ADD 字段 类型 约束 [默认值 注释] ALTER TABLE video ADD category_id int(11) unsigned not nu ...
- mysql报错无效默认值1067_Mysql 报错:#1067 - Invalid default value for 'update_time
由于 字段UPDATE_TIME 的字段类型是 timestamp ,默认值是:'0000-00-00 00:00:00' 即:`UPDATE_TIME` timestamp NOT NULL DEF ...
- mysql 日期型中文报错_mysql日期类型默认值'0000-00-00' 报错,是什么问题?
如题,本来是 从另一个数据库中导出的sql文件,在我电脑上导入报这个错误,不知道是不是mysql 版本问题.多方搜索无果,所以上来求助.DROP TABLE IF EXISTS `workreport ...
- 关于mysql设置varchar 字段的默认值''和null的区别,以及varchar和char的区别
一.背景 根据业务需求,发现以前的同事在设计表的时候,很多字段都没有设置默认值.在mysql5.7版本之后,没有设定默认值的字段,在严格模式下是很容易报错的,所以我这边需要先给每个字段加上一个默认值. ...
- mysql char null_关于mysql设置varchar 字段的默认值''和null的区别,以及varchar和char的区别...
一.背景 根据业务需求,发现以前的同事在设计表的时候,很多字段都没有设置默认值.在mysql5.7版本之后,没有设定默认值的字段,在严格模式下是很容易报错的,所以我这边需要先给每个字段加上一个默认值. ...
- Mysql设置某字段唯一
Mysql设置某字段唯一 1.建表时加上唯一性约束 CREATE TABLE `t_user` ( `Id` int(11) NOT NULL AUTO_INCREMENT, `username` ...
- mysql 设置时间字段为默认current_stamp不成功
mysql 设置时间字段为默认current_stamp不成功 解决办法: 将该字段改为datetime 类型 就可以把它的默认值设置成current_timestamp了
- 关于mysql数据库的外键插入报错:Cannot add or update a child row: a foreign key constraint fails,完整性问题
关于mysql的外键插入报错:Cannot add or update a child row: a foreign key constraint fails..... 首先确定sql语句的正确 然后 ...
- 解决mysql特殊字符或者Emoji表情插入报错问题
解决mysql特殊字符或者Emoji表情插入报错问题 原因: MySQL的utf8编码最多3个字节,Emoji表情或者某些特殊字符是4个字节,所以数据插入不了,需要修改编码. 在MySQL 的&quo ...
最新文章
- python 列表筛选数据
- 为什么放弃治疗_百度百科
- 解决 VSCode 配置 tab 空格数 Dart 语言无效的问题
- go zap去除程序名称_适用于Zip,Zap和Zoom游戏的Python程序
- Jedis使用测试——连接本地及远程的Redis
- Windows破解逆向-CrackMe_1实例(使用OpenProcess修改内存中的值)
- Android利用温度传感器实现带动画效果的电子温度计
- 1月29日云栖精选夜读 | 拿下两个世界第一,阿里人机对话模型成人工智能国际通用标准...
- 【uoj#180】[UR #12]实验室外的攻防战 结论题+树状数组
- Android工具箱之文件目录
- bt linux wifi,RK3288 添加WiFiBT模块AP6212
- HIT软件构造复习 lab篇
- “时间复杂度”的另类解释
- 超简单 图解 三级域名解析
- 工厂自动化系统,架构设计图
- 情商比智商更能决定人的一生
- 百度地图JavaScript版api使用说明
- 《Google Android开发入门与实战随书视频》
- java 金额比较大小写_Java金额大小写的转换方法
- cad怎么向下位移_CAD最简单的编辑命令:移动M也有技巧