Mybatis之@Param注解源码解析

世界上只有两种人,懒人和漫无目的的人,作为一名工程师如果不勤奋且没有目标,淘汰是必然的
学无止境 点我 跳转到Java工程师必备技术栈

目录

  • 一、使用
  • 二、源码解析

一、使用

mybatis在多参数情况下默认会将参数按顺序放入map集合,key为param1,param2

User getUserByCondition(int id,String name)
<select id="getUserByCondition" resultType="user">
    select *
    from user
    where id = #{param1}
      and name = #{param2};
select>

使用@Param可以自定义key

User getUserByCondition(@Param("id") int id, @Param("name") String name);
<select id="getUserByCondition" resultType="user">
    select *
    from user
    where id = #{id}
      and name = #{name};
select>

二、源码解析

1、debug运行并进入该方法
Mybatis之@Param注解源码解析_第1张图片
2、发现运用了代理模式,进入红框的invoke方法
Mybatis之@Param注解源码解析_第2张图片
3、再进入
在这里插入图片描述
4、sql语句的命名标识按namespace+id,类型为sql语句的类型
Mybatis之@Param注解源码解析_第3张图片
5、该方法为Select类型,接着判断方法返回值
Mybatis之@Param注解源码解析_第4张图片
6、以上都不成立,执行方法将方法参数转为sql命令的参数,进入该方法,再进入
Mybatis之@Param注解源码解析_第5张图片
7、此时不清楚names是什么,需要找出names
Mybatis之@Param注解源码解析_第6张图片
8、在该类ParamNameResolver找到names
在这里插入图片描述
9、该方法为names赋值

10、回到第7步,先看看传进去的真实参数
Mybatis之@Param注解源码解析_第7张图片
11、精华代码,含mybatis默认map的kv和自定义map的kv的设置
Mybatis之@Param注解源码解析_第8张图片
Mybatis之@Param注解源码解析_第9张图片

你可能感兴趣的:(源码,java)