mybatis异常:nested exception is org.apache.ibatis.binding.BindingException

mybatis异常:nested exception is org.apache.ibatis.binding.BindingException: Parameter ‘userI’ not foun

在使用mybatis开发的时候,有时候需要传入多个参数进行查询,当传入多个参数时,不会处理会出现下面异常:

nested exception is org.apache.ibatis.binding.BindingException: Parameter ‘userId’ not found. Available parameters are [0, 1, param1, param2]
出现上面异常的原因是*mapper.xml映射没有得到传入的参数,这个时候需要在DAO变化传参,下面对比一下错误的和正确的传参方式:

错误原因1 传递多个参数没有添加@Param 注解

错误的

public List<EquipmentUser> findEquipmentUserInfoBySystemUserId(Integer userId, String equipmentType);

要使用@Param(“userId”)注解进行传参,才能让*mapper.xml文件得到参数,

正确的写法如下:

public List<EquipmentUser> findEquipmentUserInfoBySystemUserId(@Param("userId")Integer userId, @Param("equipmentType")String equipmentType);

错误原因2 @Param 注解导错了包

注意: 有的开发者即使使用了@Param注解,还是会报这个异常,原因是在导包的时候,导入的是spring的@Param的注解包,在这里我们需要导入mybatis的@Param注解包,也就是org.apache.ibatis.annotations.Param;这个包

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_43593107/article/details/121136995

  • 31
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
nested exception is org.apache.ibatis.binding.BindingExceptionMyBatis框架中的异常,表示在执行Mapper接口方法时出现了参数绑定异常。具体的错误信息是"Parameter 'xxx' not found. Available parameters are [xxx, xxx, ...]"。这个异常通常发生在Mapper接口方法的参数与XML映射文件中定义的参数不匹配的情况下。 要解决这个异常,可以从以下几个方面入手: 1. 检查Mapper接口方法的参数名与XML映射文件中的参数名是否一致。确保参数名的一致性可以避免这个异常的出现。 2. 检查Mapper接口方法的参数个数与XML映射文件中定义的参数个数是否一致。如果个数不一致,也会导致参数绑定异常的发生。 3. 在XML映射文件中,可以使用param1、param2等占位符来表示参数的位置,而不是具体的参数名。这样可以避免参数名不一致导致的异常。 总结一下,nested exception is org.apache.ibatis.binding.BindingException表示MyBatis在执行Mapper接口方法时遇到了参数绑定异常。要解决这个问题,需要确保Mapper接口方法的参数与XML映射文件中的参数一致,并检查参数个数是否匹配。如果还是无法解决,可以考虑使用占位符来表示参数位置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [mybatis异常nested exception is org.apache.ibatis.binding.BindingException](https://blog.csdn.net/niu1109/article/details/124434791)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [nested exception is org.apache.ibatis.binding.BindingException 解决方式汇总](https://blog.csdn.net/qq_39609993/article/details/128725325)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值