org.apache.ibatis.binding.BindingException: Parameter XXX not found.的问题

今天在学springcloud alibaba seata时,遇到一个问题。

业务流程是:创建订单调用库存服务扣减库存,调用账户服务扣减账户余额,最后修改订单状态

有三个服务,订单order服务,库存storage服务和账户account服务;

将三个服务注册进alibaba的nacos,启动nacos,再启动seata,seata用来管理分布式服务间的事务

进行测试时候报错:org.apache.ibatis.binding.BindingException: Parameter 'count' not found.

查看报错内容得知,是在dao中传参

void decrease(@Param("productId") Long productId, @Param("count") Integer count);

对应的mapper

    <update id="decrease">
        update t_storage
        set used = used + #{count},residue = residue - #{count}
        where  product_id= #{productId};
    </update>

如果没有添加@Param注解,Mybatis传递参数是按位置传递的,也就是说下面一个接口:public User find(String name, String password), XML中使用参数是这样的select * from user where name = #{0} and password = #{1}。但是我这里添加了@Param注解但是依然报错。

可以确认问题就是出在这里,经过查看发现,项目中的服务调用是采用的OpenFeign,OpenFeign也有@Param的注解,在引入包的时候没有仔细看,导致引入的是OpenFeign的@Param,Mybatis识别不出来,所以默认为是按位置来识别参数,导致出错。

总结:编码时候一定要细心,一个粗心或许会浪费你很多宝贵的时间呐!

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值