mysql-[mysql - 1067问题] 1067 - Invalid default value for

1067 - Invalid default value for 问题

问题描述: 今天在用powerdesinger 创建表结构模型时 有一个字段类型 timestamp 类型, 在执行创建表结构的语句是报错 1067 - Invalid default value for ‘deleted_at’

数据库版本: 5.6.36

问题表结构如下**(实际上这个语句没有问题,和版本及数据库配置有关系)**
create table scrm_sop_general
(
 id                   int(11) not null auto_increment comment 'id',
deleted_at           timestamp default NULL comment '删除时间',
primary key (id)
)
ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='test表';

解决方案

1.解决问题前查看项

首先用下面的命令看下sql_mode
show variables like 'sql_mode';
如果查询的结果如下:
ONLY_FULL_GROUP_BY, STRICT_TRANS_TABLES, NO_ZERO_IN_DATE, NO_ZERO_DATE, 
ERROR_FOR_DIVISION_BY_ZERO, NO_AUTO_CREATE_USER, NO_ENGINE_SUBSTITUTION
如果结果中含有NO_ZERO_IN_DATE, NO_ZERO_DATE
则执行下面的命令:
set session 
sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,
NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

如果是解压版的mysql 配置如下图

在这里插入图片描述

解决方式1.
第一种解决方式就是在 timestamp 后面加 null (表多工作量大)
create table scrm_sop_general
(
 id                   int(11) not null auto_increment comment 'id',
deleted_at      timestamp null default NULL comment '删除时间',
primary key (id)
)
ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='test表';
解决方式 2. (推荐方式)
网上查找,在mysql配置文件中增加配置参数
[mysqld]节点下添加
explicit_defaults_for_timestamp = ON
重启mysql数据库试配置生效。
之后就可以正常执行上面的说的问题语句
以下是处理成功后的完整的my.ini,可作为参考
[mysql]
#设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
max_allowed_packet = 100M
#设置3306端口
port=3306
# 设置mysql的安装目录  
basedir=C:\1_app\mysql-5.7.39-winx64
# 设置mysql数据库的数据的存放目录  
datadir=C:\1_app\mysql-5.7.39-winx64\data 
# 允许最大连接数  
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集  
character-set-server=utf8  
# 创建新表时将使用的默认存储引擎  
default-storage-engine=INNODB
sql_mode=NO_ENGINE_SUBSTITUTION,NO_AUTO_CREATE_USER
innodb_lock_wait_timeout=500
explicit_defaults_for_timestamp = ON

下面是 解决方式2 具体解释,仅作记录,可以不需要知道
mysql5.6.6之前,timestamp时间类型有一个默认行为:
TIMESTAMP列如果没有明确声明NULL属性,默认为NOT NULL。(而其他数据类型,如果没有显示声明为NOT NULL,则允许NULL值。)
insert插入一条数据,TIMESTAMP的列值为NULL,会自动存储时候,会将当前timestamp存储到这个timestamp列中。

也就是说会自动分配 DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP 属性。
每次更新记录都会将timestamp列更新为当前的时间戳对应的时间值

现在mysql5.6版本以后,timestamp字段的默认行为发生的变化,多了一些限制。
如果timestamp列设置默认值为NULL,
Default NULL 这会发生报错 1067 - Invalid default value for

如果需要让timestamp列在创建表时可以为NULL值,需要将explicit_defaults_for_timestamp设为ON
explicit_defaults_for_timestamp默认为OFF关闭状态,打开后可以阻止timestamp的默认行为。

=================

逃避式 解决方法:

逃避问题方式1.
既然timestamp会报错,就直接用datetime来保存时间就可以解决的。
将updated_at类型timestamp改为datetime,这个创建表的过程能够正常运行

逃避问题方式2.
既然不能为NULL,那我改为一个固定值不就可以了吗
updated_at timestamp(0) DEFAULT ‘1970-01-01 08:00:00’,
将时间设置为unix时间戳为0对应的日期(默认是1970-01-01 00:00:00,中国时间要加8)。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 1067-invalid default value for是MySQL数据库中的错误提示,通常是由于在创建表时指定了无效的默认值导致的。这个错误提示通常会出现在MySQL版本升级后,因为新版本中默认值的规则可能会有所改变。要解决这个问题,可以检查表结构中的默认值是否符合MySQL的规则,或者修改MySQL的配置文件以允许使用旧版本的默认值规则。 ### 回答2: 1067-invalid default value for是MySQL数据库报出的错误提示,主要是由于在创建表格时指定了无效的默认值所引起。 当我们在创建数据表的时候,可能会在某一列中指定一个默认值。如果该默认值被识别为无效,则会出现1067错误。这个错误通常发生在MySQL版本更新后,因为MySQL版本升级后,数据类型的默认值有很多变化。 解决1067-invalid default value for这个错误很简单,具体命令如下: 1. 首先,你需要登录MySQL数据库,并进入你的数据库。 2. 执行命令:SET sql_mode = ''; 这个命令意思是设置当前MySQL的sql模式为默认值,这样就可以解决1067错误了。 3. 然后执行 CREATE TABLE 命令,即可成功创建数据表。 4. 如果你的MySQL版本较高,则可以使用以下命令: SET sql_mode = 'NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'; 以上命令便可以很好地解决1067-invalid default value for错误。 总之,当我们在使用MySQL数据库时,必须注意设置数据类型的默认值,否则就会出现1067错误。当出现这种错误时,可以通过设置MySQL的sql模式来解决问题。此外,在MySQL数据库的使用中,更要注意版本更新,因为版本更新也可能导致数据类型的默认值发生变化。 ### 回答3: 1067-invalid default value for是什么意思? 1067-invalid default value for是MySQL数据库中的一个错误提示信息。这个错误通常是在向数据库中插入数据时出现的,该数据包含一个无效的默认值。这个错误通常会导致数据插入失败,因此需要修复。 该错误原因很多,可能是因为在插入数据时设置了一个不存在的默认值,或者是设置了一个格式错误的默认值,还有可能是设置了不支持的默认值类型等。因此,如果出现了1067-invalid default value for错误,就需要仔细检查并确定数据中是否存在无效的默认值,然后进行修正。 如何解决1067-invalid default value for错误? 要解决1067-invalid default value for错误,需要按照以下步骤进行检查和修正: 1. 检查数据表中的默认值,确定是否存在格式错误或不支持的默认值类型。 2. 检查数据库的版本和编码设置是否正确,可能会因为版本不同或编码不匹配导致该错误。 3. 确定具体出现错误的位置,查找是哪一个字段出现了无效的默认值。这个过程可以通过MySQL提供的一些工具来完成,例如SHOW CREATE TABLE、DESC和EXPLAIN等命令。 4. 如果发现数据表中设置了无效的默认值,则需要修改相应字段的默认值设置,或者完全删除这个无效的默认值,然后重新插入数据。 综上所述,1067-invalid default value for错误是一个比较常见的MySQL数据库错误,出现了这个错误就需要仔细排查和修正,以确保数据表中的默认值正确有效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值