版本:mysql5.7 執(zhí)行sql:
執(zhí)行結(jié)果:ERROR 1067 (42000): Invalid default value for 'end_time' 原因是:mysql5.7的explicit_defaults_for_timestamp參數(shù)默認(rèn)是OFF與sql_mode的NO_ZERO_DATE沖突 通過執(zhí)行mysql>show variables;查看explicit_defaults_for_timestamp和sql_mode變量的值 explicit_defaults_for_timestamp = OFF 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 分析過程: 1)在默認(rèn)情況下,如果TIMESTAMP列沒有顯示的指明null屬性,那么該列會被自動加上not null屬性(而其他類型的列如果沒有被顯示的指定not null,那么是允許null值的),如果往這個列中插入null值,會自動的設(shè)置該列的值為current timestamp值。 2)表中的第一個TIMESTAMP列,如果沒有指定null屬性或者沒有指定默認(rèn)值,也沒有指定ON UPDATE語句。那么該列會自動被加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP屬性。 3)第一個TIMESTAMP列之后的其他的TIMESTAMP類型的列,如果沒有指定null屬性,也沒有指定默認(rèn)值,那么該列會被自動加上DEFAULT ‘0000-00-00 00:00:00’屬性。如果insert語句中沒有為該列指定值,那么該列中插入’0000-00-00 00:00:00’,并且沒有warning。 解決辦法: mysql>set @@explicit_defaults_for_timestamp = 1; 1)此時如果TIMESTAMP列沒有顯示的指定not null屬性,那么默認(rèn)的該列可以為null,此時向該列中插入null值時,會直接記錄null,而不是current timestamp。 2)不會自動的為表中的第一個TIMESTAMP列加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP屬性,除非你在建表的時候顯示的指明。 3)如果TIMESTAMP列被加上了not null屬性,并且沒有指定默認(rèn)值。這時如果向表中插入記錄,但是沒有給該TIMESTAMP列指定值的時候,如果strict sql_mode被指定了,那么會直接報錯。如果strict sql_mode沒有被指定,那么會向該列中插入’0000-00-00 00:00:00’并且產(chǎn)生一個warning。 NO_ZERO_DATE: 在這個模式下,不允許時間值為'0000-00-00 00:00:00'格式; 解決辦法: mysql>set @@sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'; 去掉NO_ZERO_IN_DATE,NO_ZERO_DATE 重啟服務(wù)器,正常執(zhí)行創(chuàng)建語句. |
|