mysql5.7之后版本 datetime/timestamp 默認(rèn)值0或0000-00-00 00:00:00出錯(cuò)
出現(xiàn)異常:Invalid default value for 'create_time'
原因:
mysql5.7之后版本的sql_mode默認(rèn)使用:
mysql> 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,
NO_ENGINE_SUBSTITUTION
其中NO_ZERO_IN_DATE, NO_ZERO_DATE兩個(gè)選項(xiàng)禁止了0000這樣的日期和時(shí)間。因此在mysql的配置文件中,重新設(shè)置sql_mode,去掉這兩項(xiàng)就可以了。
解決辦法:
臨時(shí)修改
mysql> set global sql_mode=‘ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION‘ ;
mysql> set session sql_mode=‘ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION‘ ;
永久修改
修改my.cnf文件,在[mysqld]中添加
sql-mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION