Mysql 0000-00-00 00:00:00报错解决

  • 遇到0000-00-00 00:00:00 Invalid date
  • 原因:5.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
  • 解决方法:SET [SESSION|GLOBAL] sql_mode=’设置’,这种方法重连数据库失效
$ 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 
// 例 其中:SESSION只在当前会话中生效,GLOBAL为全局生效。 
$SET GLOBAL sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
  • 方法二:把报错数据转成 null,一定要用下面的语句,否则会报错
$ update waybills SET arrive_at = NULL where CAST(arrive_at AS CHAR(20)) = '0000-00-00 00:00:00';
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值