com.alibaba.druid.sql.parser.ParserException: syntax error, expect ')', pos 40, line 1, column 41, token EOF
使用mybatis-plus批量插入的时候报错信息为:com.alibaba.druid.sql.parser.ParserException: syntax error, expect ')', pos 40, line 1, column 41, token EOF
排查sql日志发现生成的sql为:
Preparing: INSERT INTO ods_zq_zqgs_zqtz_m VALUES
merge sql error, dbType mysql, druid-1.1.22, sql : INSERT INTO ods_zq_zqgs_zqtz_m VALUES
com.alibaba.druid.sql.parser.ParserException: syntax error, expect ')', pos 40, line 1, column 41, token EOF
可以看出,是sql语法错误,缺失了小括号), 看上面的语句很明显可以看出,生成的sql语句values后面缺失了括号。
SQL缺失括号的原因
mybatis-plus批量插入的字段生成依赖对象的属性值,当对象属性值都是null的时候,就发生了上述错误!总得来说算是mybatis-plus的bug。但是考虑的业务上居然插入了一条全是null的记录,确实也不合理!所以说,这个bug的抛出来让开发者解决也可以理解。
解决办法
注意插入的对象是否全部属性为null,将某些属性赋值值,或干脆去除此记录即可!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· [翻译] 为什么 Tracebit 用 C# 开发
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· 2分钟学会 DeepSeek API,竟然比官方更好用!
· .NET 使用 DeepSeek R1 开发智能 AI 客户端
· 刚刚!百度搜索“换脑”引爆AI圈,正式接入DeepSeek R1满血版