日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

ERROR 1067 (42000): Invalid default value for 'end

 XSMforever 2019-05-25

版本:mysql5.7

執(zhí)行sql:

CREATE TABLE seckill(
  `seckill_id` BIGINT NOT NUll AUTO_INCREMENT COMMENT '商品庫(kù)存ID',
  `name` VARCHAR(120) NOT NULL COMMENT '商品名稱',
  `number` int NOT NULL COMMENT '庫(kù)存數(shù)量',
  `start_time` TIMESTAMP  NOT NULL  COMMENT '秒殺開始時(shí)間',
  `end_time` TIMESTAMP  NOT NULL  COMMENT '秒殺結(jié)束時(shí)間',
  `create_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創(chuàng)建時(shí)間',
  PRIMARY KEY (seckill_id),
  key idx_start_time(start_time),
  key idx_end_time(end_time),
  key idx_create_time(create_time)
)ENGINE=INNODB AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 COMMENT='秒殺庫(kù)存表';

執(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屬性,那么該列會(huì)被自動(dòng)加上not null屬性(而其他類型的列如果沒有被顯示的指定not null,那么是允許null值的),如果往這個(gè)列中插入null值,會(huì)自動(dòng)的設(shè)置該列的值為current timestamp值。

2)表中的第一個(gè)TIMESTAMP列,如果沒有指定null屬性或者沒有指定默認(rèn)值,也沒有指定ON UPDATE語(yǔ)句。那么該列會(huì)自動(dòng)被加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP屬性。

3)第一個(gè)TIMESTAMP列之后的其他的TIMESTAMP類型的列,如果沒有指定null屬性,也沒有指定默認(rèn)值,那么該列會(huì)被自動(dòng)加上DEFAULT ‘0000-00-00 00:00:00’屬性。如果insert語(yǔ)句中沒有為該列指定值,那么該列中插入’0000-00-00 00:00:00’,并且沒有warning。

解決辦法:

mysql>set @@explicit_defaults_for_timestamp = 1;

1)此時(shí)如果TIMESTAMP列沒有顯示的指定not null屬性,那么默認(rèn)的該列可以為null,此時(shí)向該列中插入null值時(shí),會(huì)直接記錄null,而不是current timestamp。

2)不會(huì)自動(dòng)的為表中的第一個(gè)TIMESTAMP列加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP屬性,除非你在建表的時(shí)候顯示的指明。

3)如果TIMESTAMP列被加上了not null屬性,并且沒有指定默認(rèn)值。這時(shí)如果向表中插入記錄,但是沒有給該TIMESTAMP列指定值的時(shí)候,如果strict  sql_mode被指定了,那么會(huì)直接報(bào)錯(cuò)。如果strict sql_mode沒有被指定,那么會(huì)向該列中插入’0000-00-00 00:00:00’并且產(chǎn)生一個(gè)warning。

NO_ZERO_DATE:

在這個(gè)模式下,不允許時(shí)間值為'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)建語(yǔ)句.

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多