水滴石穿——非一日之功

MyBatis中抽象方法中多个参数的问题

 
在使用MyBatis时,接口中的抽象方法只允许有1个参数,如果有多个参数,例如:
 
    Integer updatePassword(
            Integer id, String password);
 
在最终运行时,Java源代码会被编译成.class文件,就会丢失参数名称,所以,运行时会提示“找不到某参数”的错误:
 
    Caused by: org.apache.ibatis.binding.BindingException: Parameter 'password' not found. Available parameters are [arg1, arg0, param1, param2]
 
解决方案就是“封装”,例如将以上2个参数id、password封装到1个User对象中,或将这2个参数封装到1个Map对象中……但是,无论哪种做法,都存在调用方法不便利的问题,MyBatis提供的解决方案就是添加注解:
 
    Integer updatePassword(
        @Param("id") Integer id,  
        @Param("password") String password);
 
通过`@Param`注解,当执行时,MyBatis会将多个参数封装为1个Map对象来执行,就不需要开发人员自行封装! ,所以MyBatis本质还是只接受一个参数
 
也可以小结为:当抽象方法的参数超过1个时,必须添加`@Param`注解,并且,在XML配置中,使用`#{}`表示的变量的名称其实是`@Param`注解中的值!

 

    Integer updatePassword(
        @Param("id") Integer id, 
        @Param("password") String password);
<update id="updatePassword">
        UPDATE 
            t_user
        SET 
            password=#{password}
        WHERE 
            id=#{id}
    </update>

 

posted @ 2019-03-08 15:39  滑稽的鼠标  阅读(201)  评论(0编辑  收藏  举报
/*粒子线条,鼠标移动会以鼠标为中心吸附的特效*/