mysql 修复插入零日期报错

文章目录

问题

数据插入mysql时报错

部分关键内容如下

bash 复制代码
Incorrect datetime value: '0000-00-00' for column 'createdAt' at row 1

解决

原因

从MySQL 5.7.5开始,默认情况下不允许插入零日期或零时间值到DATETIME或 TIMESTAMP列。

实际是因为SQL模式包含NO_ZERO_DATE,禁止零日期

处置

  1. 查看mysql模式
bash 复制代码
SELECT @@GLOBAL.sql_mode;
+-----------------------------------------------------------------------------------------------------------------------+
| @@GLOBAL.sql_mode                                                                                                     |
+-----------------------------------------------------------------------------------------------------------------------+
| ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION |
+-----------------------------------------------------------------------------------------------------------------------+
1 row in set (0.02 sec)
  1. 修改模式
bash 复制代码
SET GLOBAL sql_mode = REPLACE(@@GLOBAL.sql_mode, 'NO_ZERO_DATE', '');

修改完毕后即可插入零日期,然后由建表语句时的设置插入当前时间等等。

reference

相关推荐
用户9828630256814 小时前
pg内核实现细节
数据库
码界筑梦坊14 小时前
330-基于Python的社交媒体舆情监控系统
python·mysql·信息可视化·数据分析·django·毕业设计·echarts
飞升不如收破烂~14 小时前
Redis 分布式锁+接口幂等性使用+当下流行的限流方案「落地实操」+用户连续点击两下按钮的解决方案自用总结
数据库·redis·分布式
workflower14 小时前
业务需求-假设场景
java·数据库·测试用例·集成测试·需求分析·模块测试·软件需求
亓才孓14 小时前
[JDBC]基于三层架构和MVC架构的JDBCTools
数据库
IT邦德14 小时前
RPM包快速安装Oracle26ai
数据库·oracle
Dovis(誓平步青云)14 小时前
《滑动窗口算法:从 “暴力遍历” 到 “线性高效” 的思维跃迁》
运维·服务器·数据库·算法
mr_LuoWei200914 小时前
python工具:python代码知识库笔记
数据库·python
这周也會开心15 小时前
Redis数据类型的底层实现和数据持久化
数据库·redis·缓存
ん贤15 小时前
一次批量删除引发的死锁,最终我选择不加锁
数据库·安全·go·死锁