• 周六. 7 月 27th, 2024

    MySQL5.7版本以上 datetime默认值设置0000-00-00失败的问题

    root

    7 月 14, 2021 #MySQL

    mysql5.7之后版本datetime默认值设置’0000-00-00’,出现异常:Invalid default value for ‘create_time’

    原因:

    mysql5.7之后版本的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,去掉这两项就可以了。

    即:在/etc/my.conf文件中 [mysqld]下添加

    sql-mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

    然后重新启动mysql服务 /etc/init.d/mysql restart

    root