天天看点

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识别不出来,所以默认为是按位置来识别参数,导致出错。

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