首页 >数据库 >mysql教程 >如何修复 MySQL 错误 1292:'日期时间值不正确”?

如何修复 MySQL 错误 1292:'日期时间值不正确”?

Patricia Arquette
Patricia Arquette原创
2024-12-02 09:07:13670浏览

How to Fix MySQL Error 1292:

不正确的日期时间值:解决 MySQL 错误 1292

在转换日期时间值存储为“0000-00-00 00”的现有数据库时: 00:00',用户可能会遇到 MySQL 错误 1292:“日期时间值不正确。”出现此错误的原因是原始 MySQL 数据库(例如 5.1)和较新版本(例如 5.7)之间存在版本冲突,它们对日期时间值的处理方式不同。

要解决此问题,可以采取以下步骤:

选项 1:将 '0000-00-00 00:00:00' 转换为NULL

  1. 尝试使用以下查询将包含 '0000-00-00 00:00:00' 的日期时间列转换为 NULL:
ALTER TABLE users MODIFY created datetime NULL DEFAULT '1970-01-01 00:00:00';

如果失败,请继续执行选项2.

选项 2:使用 CHAR 转换

  1. 仅当日期时间列的值为 '0000-00- 时,才通过将日期时间列设置为 NULL 来更新受影响的行00 00:00:00' 作为一个字符string:
UPDATE users SET created = NULL WHERE CAST(created AS CHAR(20)) = '0000-00-00 00:00:00';

此替代查询使用 CAST 函数将日期时间值转换为 20 个字符的字符串,并且仅更新结果与 '0000-00-00 00:00 匹配的行: 00'.

更新完成后,您应该能够成功修改数据库表的字符集和排序规则,而不会遇到错误的日期时间值错误。

以上是如何修复 MySQL 错误 1292:'日期时间值不正确”?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn