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

测试

没毛病!!!

  • 编写有误还请大佬指正,万分感谢。
相关推荐
MaxHua25 分钟前
以 AI 之力重塑 Java 研发,解锁高效开发新范式
后端
Determined_man27 分钟前
多了这个@ResponseBody和没加有什么区别?
后端
八苦30 分钟前
VKProxy新增一些功能
后端
ApeAssistant36 分钟前
Log4j2.xml配置总结,就这个标题就挺好
后端·apache log4j
WanderInk1 小时前
揭秘Java协变返回类型:让你的API少一点强转,多一点优雅
java·后端
心在飞扬1 小时前
AI开发应用 01-nodejs快速入门
后端·aigc·dnodejs
Ray661 小时前
「阅读笔记」elasticSearch 是什么?工作原理是怎么样的?
后端
paopaokaka_luck1 小时前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
蓝倾1 小时前
淘宝批量获取商品SKU实战案例
前端·后端·api