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, param2mybatis底层是做了处理的,这种写法是识别不到你自定义写的字段的,可以使用arg0,或者parma1来替代使用,arg0代表的是第一个参数,parima则是从1开始。

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

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

解决

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

测试

没毛病!!!

  • 编写有误还请大佬指正,万分感谢。
相关推荐
JaguarJack4 分钟前
免费可商用 PHP 管理后台 CatchAdmin V5.3.1 发布 后台打包直降 5s 内
后端·php·laravel
雨辰AI9 分钟前
MySQL 迁移至达梦 DM9 完整改造指南|99% SQL 零改动
java·开发语言·数据库·sql·mysql·政务
小张小张爱学习1 小时前
Spring Boot 多线程并发入门教程:ThreadPoolTaskExecutor + CompletableFuture
java·spring boot·后端
西安邮电大学1 小时前
Redis核心数据结构以及应用场景
java·redis·后端·其他·面试
AskHarries1 小时前
做 SaaS 还是做 App
后端
朝阳5811 小时前
MySQL 主从复制 — Docker 双机灾备方案
数据库·mysql·docker
染翰1 小时前
生产级 MySQL 内存占用过高排查指南
数据库·mysql
卷无止境1 小时前
银行里的"等不了"——SimPy Bank Renege 示例全解析
后端
星栈1 小时前
别再满项目乱丢 String:我开始给领域错误分层了
后端·代码规范
卷无止境2 小时前
SimPy 监控与数据收集:完整指南
后端