Mybatis操作sql报错ibatis.binding.BindingException: Parameter 'empId' not found.

你们好,我是金金金。

场景

  • 在使用Mybatis操作sql语句过程当中,更新操作,报错信息如下:Caused by: org.apache.ibatis.binding.BindingException: Parameter 'empId' not found. Available parameters are [arg1, arg0, param1, param2],未找到参数"empId"。 可用参数为 [arg1, arg0, param1, param2]

附上代码

  • mapper接口
  • mapper.xml文件
  • test

排查

  • 从报错信息得知:可用参数为[arg1, arg0, parma1, param2],mybatis底层是做了处理的,这种写法是识别不到你自定义写的字段的,可以使用arg0,或者parma1来替代使用,arg0代表的是第一个参数,parima则是从1开始。

我这里就测试arg0和arg1这种方式了。

可以看到没有任何问题,但是不推荐上面这种写法,参数多了容易混淆,导致蒙蔽,以下有一种更好的写法,请继续往下看

解决

  • 使用@Param注解标记方法参数,明确指定参数的名称,这样xml文件就可以识别到了

测试

没毛病!!!

  • 编写有误还请大佬指正,万分感谢。
相关推荐
HyggeBest2 分钟前
Golang 并发原语 Sync Cond
后端·架构·go
老张聊数据集成5 分钟前
数据建模怎么做?一文讲清数据建模全流程
后端
颜如玉26 分钟前
Kernel bypass技术遥望
后端·性能优化·操作系统
一块plus40 分钟前
创造 Solidity、提出 Web3 的他回来了!Gavin Wood 这次将带领波卡走向何处?
javascript·后端·面试
funfan05171 小时前
在IDEA中DEBUG调试时查看MyBatis-Plus动态生成的SQL语句
sql·intellij-idea·mybatis
用户298698530141 小时前
C#代码:Word文档加密与解密(Spire.Doc)
后端
海海思思1 小时前
Go结构体字段提升与内存布局完全指南:从报错解析到高效实践
后端
程序员岳焱1 小时前
使用 JPype 实现 Java 与 Python 的深度交互
java·后端·python
LSTM971 小时前
使用C#实现Excel与DataTable互转指南
后端
neoooo1 小时前
JDK 新特性全景指南:从古早版本到 JDK 17 的华丽变身
java·spring boot·后端