一、问题描述

在往数据库写入数据的时候,报错:

'字段名' 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相关推荐

  1. MySQL语句增加字段,修改字段名,修改类型,修改默认值

    增加字段: alter table 表名 ADD 字段 类型 约束 [默认值 注释] ALTER TABLE video ADD category_id int(11) unsigned not nu ...

  2. 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 ...

  3. mysql 日期型中文报错_mysql日期类型默认值'0000-00-00' 报错,是什么问题?

    如题,本来是 从另一个数据库中导出的sql文件,在我电脑上导入报这个错误,不知道是不是mysql 版本问题.多方搜索无果,所以上来求助.DROP TABLE IF EXISTS `workreport ...

  4. 关于mysql设置varchar 字段的默认值''和null的区别,以及varchar和char的区别

    一.背景 根据业务需求,发现以前的同事在设计表的时候,很多字段都没有设置默认值.在mysql5.7版本之后,没有设定默认值的字段,在严格模式下是很容易报错的,所以我这边需要先给每个字段加上一个默认值. ...

  5. mysql char null_关于mysql设置varchar 字段的默认值''和null的区别,以及varchar和char的区别...

    一.背景 根据业务需求,发现以前的同事在设计表的时候,很多字段都没有设置默认值.在mysql5.7版本之后,没有设定默认值的字段,在严格模式下是很容易报错的,所以我这边需要先给每个字段加上一个默认值. ...

  6. Mysql设置某字段唯一

    Mysql设置某字段唯一 1.建表时加上唯一性约束   CREATE TABLE `t_user` ( `Id` int(11) NOT NULL AUTO_INCREMENT, `username` ...

  7. mysql 设置时间字段为默认current_stamp不成功

    mysql 设置时间字段为默认current_stamp不成功 解决办法: 将该字段改为datetime 类型 就可以把它的默认值设置成current_timestamp了

  8. 关于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语句的正确 然后 ...

  9. 解决mysql特殊字符或者Emoji表情插入报错问题

    解决mysql特殊字符或者Emoji表情插入报错问题 原因: MySQL的utf8编码最多3个字节,Emoji表情或者某些特殊字符是4个字节,所以数据插入不了,需要修改编码. 在MySQL 的&quo ...

最新文章

  1. python 列表筛选数据
  2. 为什么放弃治疗_百度百科
  3. 解决 VSCode 配置 tab 空格数 Dart 语言无效的问题
  4. go zap去除程序名称_适用于Zip,Zap和Zoom游戏的Python程序
  5. Jedis使用测试——连接本地及远程的Redis
  6. Windows破解逆向-CrackMe_1实例(使用OpenProcess修改内存中的值)
  7. Android利用温度传感器实现带动画效果的电子温度计
  8. 1月29日云栖精选夜读 | 拿下两个世界第一,阿里人机对话模型成人工智能国际通用标准...
  9. 【uoj#180】[UR #12]实验室外的攻防战 结论题+树状数组
  10. Android工具箱之文件目录
  11. bt linux wifi,RK3288 添加WiFiBT模块AP6212
  12. HIT软件构造复习 lab篇
  13. “时间复杂度”的另类解释
  14. 超简单 图解 三级域名解析
  15. 工厂自动化系统,架构设计图
  16. 情商比智商更能决定人的一生
  17. 百度地图JavaScript版api使用说明
  18. 《Google Android开发入门与实战随书视频》
  19. java 金额比较大小写_Java金额大小写的转换方法
  20. cad怎么向下位移_CAD最简单的编辑命令:移动M也有技巧

热门文章

  1. namespace nvinfer1
  2. python opencv投影变换增强
  3. android EditText显示不全
  4. torch.squeeze()和unsqueeze()
  5. Python 查重,统计重复 排序
  6. Windows安装Pytorch/torchvision
  7. OpenCV学习之六: 使用方向梯度直方图估计图像旋转角度
  8. Numpy中的transpose
  9. mysql unoin排序
  10. webbrowser php,C# WinForm WebBrowser 设置为编辑模式的示例代码