字段类型date, datetime设置0000-00-00默认值报错
现象:用sql创建表时,date, datetime类型设置默认值"0000-00-00",出现异常:Invalid default value for 'time',MySQL版本5.7
原因: 查看当前的sql_mode配置:
select @@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, and NO_ENGINE_SUBSTITUTION
其中NO_ZERO_IN_DATE
, NO_ZERO_DATE
两个选项禁止了0000这样的日期和时间。因此在mysql的配置文件中,重新设置sql_mode,去掉这两项就可以了。
修改my.cnf
文件,在[mysqld]
中添加
sql-mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
修改完成一定重启MySQL
service mysqld restart
上次更新: 2023/03/03, 13:18:42