简单介绍MySQL数据库中日期中包含零值的问题

下面小编就为大家带来一篇浅谈mysql数据库中日期中包含零值的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

默认情况下MySQL是可以接受在日期中插入0值,对于现实来说日期中的0值又没有什么意义。调整MySQL的sql_modemysql数据库就能达到目的。

set @@global.sql_mode='STRICT_TRANS_TABLES,NO_ZERO_DATE,NO_ENGINE_SUBSTITUTION';  set @@session.sql_mode='STRICT_TRANS_TABLES,NO_ZERO_DATE,NO_ENGINE_SUBSTITUTION';

例子:

有一个用于记录日志的表

create table app_logs(  id int not null auto_increment primary key,  log_tm timestamp not null,  log_info varchar(64) not null)  engine=innodb,charset=utf8;

向日志表插入有意思的日期值

insert into app_logs(log_tm,log_info) values(now(),'log_info_1');  insert into app_logs(log_tm,log_info) values('2016-12-01','log_info_2');

向日志表插入包涵0的日期值

insert into app_logs(log_tm,log_info) values('2016-12-00','log_info_2');  ERROR 1292 (22007): Incorrect datetime value: '2016-12-00' for column 'log_tm' at row 1

© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享