mysql时区问题导致错误Incorrect datetime value: '1970-01-01 00:00:01'

手册中的描述:

A timestamp. The range is ‘1970-01-01 00:00:01’ UTC to ‘2038-01-19
03:14:07’ UTC.

注意末尾的UTC,此为世界协调时,指的是经度0度上的标准时间。

官方文档中描述:

MySQL converts TIMESTAMP values from the current time zone to UTC for
storage, and back from UTC to the current time zone for retrieval.
(This does not occur for other types such as DATETIME.) By default,
the current time zone for each connection is the server’s time. The
time zone can be set on a per-connection basis. As long as the time
zone setting remains constant, you get back the same value you store.
If you store a TIMESTAMP value, and then change the time zone and
retrieve the value, the retrieved value is different from the value
you stored. This occurs because the same time zone was not used for
conversion in both directions. The current time zone is available as
the value of the time_zone system variable.

文中说到,在存储时会根据当前环境的的时区转换为UTC存储。

而环境中的时区为CST中国标准时间,比UTC要早8个小时,常见表示为GMT+0800 (中国标准时间)。
也正是如此,输入的值存储时需要加八个小时再存储,对应过来timestamp的时间范围表示为’1970-01-01 08:00:01’ and ‘2038-01-19 11:14:07’。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中,出现"Incorrect datetime value: '0000-00-00 00:00:00' for column"错误的原因是因为MySQL 5.7版本以上默认启用了严格模式(SQL_Mode)。在严格模式下,日期和时间字段的值不允许为0,因此当插入或更新操作中的日期字段值为'0000-00-00 00:00:00'时,就会出现这个错误。 要解决这个问题,有几种方法可以尝试: 1. 修改严格模式:可以通过修改MySQL的配置文件,将严格模式禁用或修改为宽松模式。在my.cnf或my.ini文件中找到sql_mode选项,并移除其中的"NO_ZERO_DATE"和"NO_ZERO_IN_DATE"选项[3]。然后重新启动MySQL服务,使修改生效。 2. 修改数据值:将日期字段值改为有效的日期值,而不是'0000-00-00 00:00:00'。例如,可以将日期字段值设置为当前日期或其他有效日期。 3. 修改表结构:如果允许,可以修改表结构,将日期字段的默认值改为NULL或有效的日期值。这样在插入或更新操作中没有提供日期值时,将自动使用默认值,避免了出现错误。 需要注意的是,修改MySQL的配置文件或表结构都需要谨慎操作,特别是在生产环境中。建议在进行修改之前先备份相关数据和配置文件,以防止意外情况的发生。 总结起来,要解决"Incorrect datetime value: '0000-00-00 00:00:00' for column"错误,可以尝试修改MySQL的严格模式、修改数据值或修改表结构。根据具体情况选择合适的方法来解决该问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值