运行项目,sql报错无效索引 已解决

报错内容:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.type.TypeException: Could not set parameters for mapping: ParameterMapping{property='dto.inDeptCode', mode=IN, javaType=class java.lang.Object, jdbcType=VARCHAR, numericScale=null, resultMapId='null', jdbcTypeName='null', expression='null'}. Cause: org.apache.ibatis.type.TypeException: Error setting non null for parameter #5 with JdbcType VARCHAR . Try setting a different JdbcType for this parameter or a different configuration property. Cause: org.apache.ibatis.type.TypeException: Error setting non null for parameter #5 with JdbcType VARCHAR . Try setting a different JdbcType for this parameter or a different configuration property. Cause: java.sql.SQLException: 无效的列索引

原因:在这个sql语句里,if便签的前后我写了注释。在 MyBatis 的 XML 映射文件中,如果在 <if> 等动态标签前后添加注释,这些注释可能会被原样拼接到 SQL 语句中,破坏原有的语法结构(例如导致 WHERE 子句前后出现多余的 AND/OR 或括号不匹配),使得生成的 SQL 语句逻辑混乱甚至语法错误,进而导致数据库执行时无法正确解析查询条件,出现"无效索引"或直接报错;删除注释后,SQL 恢复为正确的动态拼接逻辑,问题即可解决。

解决:删除注释,重新运行,报错解决

相关推荐
A.说学逗唱的Coke7 小时前
【大模型专题】向量数据库深度解析:从原理到实战,构建企业级 AI 知识检索底座
数据库·人工智能
果丁智能8 小时前
智能锁赋能网约房民宿数字化管控:身份核验+远程授权,筑牢安全防线、降本增效
网络·数据库·人工智能·安全·智能家居
无敌的牛8 小时前
redis学习过程
数据库·redis·学习
IT北辰8 小时前
神通数据库管理系统V7.0.251210 for Windows(x86 64bit)安装部署
数据库·神通
北顾笙9809 小时前
MySQL-day2
数据库·mysql
Demons_kirit9 小时前
新项目如何连接上自己本地的数据库
数据库
洪晓露10 小时前
将 rke2 集群证书延长至 10 年
运维·服务器·数据库
程序猿乐锅10 小时前
【MySQL | 第八篇】MySQL 视图
数据库·mysql
jieyucx11 小时前
SQL 查询终极高阶通鉴:从零基础拆解到工业级多表联查、窗口函数与索引优化
数据库·sql
ai_coder_ai12 小时前
论 NoSQL 数据库技术及其应用
数据库·nosql