zoukankan      html  css  js  c++  java
  • 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

    原文地址:https://blog.csdn.net/LJFPHP/article/details/81939189
  • 相关阅读:
    守护进程、互斥锁、生产者消费者模型
    实现并发编程的基础理论
    udp协议
    进程与进程池
    tcp协议产生-粘包问题的解决方案
    day21面向对象_类
    day16_面向过程编程与模块导入
    day15_函数递归_匿名函数_内置函数
    三、运算符(阶段二)
    二、(续)基础语法--常量、变量和注释(阶段二)
  • 原文地址:https://www.cnblogs.com/jpfss/p/11190014.html
Copyright © 2011-2022 走看看