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文件就可以识别到了

测试

没毛病!!!

  • 编写有误还请大佬指正,万分感谢。
相关推荐
Go高并发架构_王工3 分钟前
MySQL性能优化案例分析:从问题到解决方案
数据库·mysql·性能优化
村口张大爷16 分钟前
Spring Boot 初始化钩子
java·spring boot·后端
IT_陈寒29 分钟前
Java性能调优:从GC日志分析到实战优化的5个关键技巧,让你的应用快如闪电!
前端·人工智能·后端
汪小成30 分钟前
阿里云服务器安装Codes免费项目管理平台
后端
Mintopia35 分钟前
🚀 Next.js API 压力测试:一场前端与后端的“极限拉扯”
前端·后端·全栈
别或许1 小时前
在centos系统下,安装MYSQL
linux·mysql·centos
丁丁丁梦涛1 小时前
CentOS修改MySQL数据目录后重启失败的问题及解决方案
linux·mysql·centos
IPFLY全球代理1 小时前
Java和Python有什么区别?从语法到应用场景的差异
后端
唐叔在学习1 小时前
venv - Python最佳的轻量化环境隔离方式
后端·python
老青蛙1 小时前
权限系统设计-角色资源设计
后端