Mysql疑难报错排查 - Field ‘XXX‘ doesn‘t have a default value

news/2025/2/9 1:44:28 标签: mysql, 数据库

项目场景:

数据库环境mysql8;
工程使用:MyBatisPlus
表情况
在这里插入图片描述


问题描述

某一个插入语句使用了 MyBatisPlus 的 save 方法,因为end_time1 end_time2都并没有值,所以在MyBatisPlus默认情况下,并不会在插入语句中提及,

最终提取其SQL: INSERT INTO aaaa (serial_no, business_date, market_no, report_code)
VALUES (31, 20230704, 1, ‘688610’)

结果报错 Field 'end_time1' doesn't have a default value
在这里插入图片描述
一般情况下,这种报错是表设置成非空字段,我们又没设置默认值导致的。但是这里我们明明表中设置了可空。而且该场景为偶现,我们单独把SQL提取出来执行又是可以的,排查数小时无果。


原因分析:

偶现,目前无法查出其原因,可能需要去Mysql源码来看原因了


解决方案:

既然说的是没有默认值,那我们就在插入的时候指定传null 进去即可,由于MyBatisPlus的特性,所以最终在DBclass层,为end_time1和end_time2都设置为null 也插入和更新
在这里插入图片描述
该参数的运行原理可见往期博文《MybatisPlus 构造器wrapper的使用与原理》 中的“易错点-null处理”小节

最终生成的SQL如下:

INSERT INTO aaaa ( serial_no, business_date,
market_no, report_code, end_time1, end_time2 ) VALUES ( 63, 20230704,
1, ‘688610’, , )

修复后没有再次报错。


http://www.niftyadmin.cn/n/5845444.html

相关文章

国内知名Deepseek培训师培训讲师唐兴通老师讲授AI人工智能大模型实践应用

课程名称 《Deepseek人工智能大模型实践应用》 课程目标 全面了解Deepseek人工智能大模型的技术原理、功能特点及应用场景。 熟练掌握Deepseek大模型的提示词工程技巧,能够编写高质量的提示词。 掌握Deepseek大模型在办公、营销等领域的应用方法,提升…

QT全局所有QSS样式实时切换

方法如下: void loadQss(int qssType) {QString name;if (qssType 1)name ":/qss/day.qss";elsename ":/qss/night.qss";QFile file(name);file.open(QFile::ReadOnly);QString qss;qss file.readAll();qApp->setStyleSheet(qss);file.…

6 maven工具的使用、maven项目中使用日志

文章目录 前言一、maven:一款管理和构建java项目的工具1 基本概念2 maven的安装与配置(1)maven的安装(2)IDEA集成Maven配置当前项目工程设置 maven全局设置 (3)创建一个maven项目 3 pom.xml文件…

多数据源配置及使用,在同一个方法下切换数据源。

切换数据源方法: 1. 通过注解切换数据源,可以在方法上使用也可以在类上使用,遵循就近原则 DS(“数据源名”) 注意:在同一个方法使用多个数据源不要使用Transactional,会导致报错。 2. 方法中手动切换 切换数据源类…

Excel 融合 deepseek

效果展示 代码实现 Function QhBaiDuYunAIReq(question, _Optional Authorization "Bearer ", _Optional Qhurl "https://qianfan.baidubce.com/v2/chat/completions")Dim XMLHTTP As ObjectDim url As Stringurl Qhurl 这里替换为你实际的URLDim postD…

PostGIS:使用shp2pgsql、pgsql2shp、OGR2OGR函数进行数据导入、导出

数据导入与导出函数 数据库数据导入与导出可以通过多个函数完成,QGIS文档介绍了3个函数: shp2pgsql、pgsql2shp、OGR2OGR,分别用于shp导入数据库、数据库文件导出为shp、数据转换为多种数据格式。 (1)shp2pgsql 在l…

zephyr devicetree

Syntax and structure — Zephyr Project Documentation Input files There are four types of devicetree input files: sources (.dts) includes (.dtsi) overlays (.overlay) bindings (.yaml) The devicetree files inside the zephyr directory look like this: …

65.棋盘 C#例子 WPF例子

这是一个不具备任何功能的UI设计&#xff0c;使用矩形和边界和文字块。通过这些可以自由的创建不同显示效果的内容。 棋盘展示&#xff1a; 代码展示&#xff1a; <Window x:Class"棋盘设计.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xam…