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

测试

没毛病!!!

  • 编写有误还请大佬指正,万分感谢。
相关推荐
HappyAcmen1 小时前
关于Redis的面试题目及其答案
数据库·redis·面试
代码欢乐豆1 小时前
NoSQL——期末复习(4)第四章HBase重点思考题
数据库·nosql·hbase
PersistJiao1 小时前
Couchbase是不是MPP数据库
数据库·couchbase
drebander2 小时前
SQL 中复杂 CASE WHEN 嵌套逻辑优化
数据库·sql
C++忠实粉丝2 小时前
Redis Hash哈希
redis·mybatis·哈希算法
撸码到无法自拔3 小时前
72 mysql 的客户端和服务器交互 returnGeneratedKeys
运维·服务器·数据库·mysql
孙尚香蕉3 小时前
深入剖析MySQL数据库架构:核心组件、存储引擎与优化策略(二)
数据库·oracle
fengyehongWorld3 小时前
Oracle 多租户架构简介
数据库·oracle
码农君莫笑3 小时前
SQL Server中最大并行度详解
服务器·数据库·sql·sqlserver
凡人的AI工具箱3 小时前
每天40分玩转Django:Django Celery
数据库·后端·python·django·sqlite