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运行并进入该方法
在这里插入图片描述
2、发现运用了代理模式,进入红框的invoke方法
在这里插入图片描述
3、再进入
在这里插入图片描述
4、sql语句的命名标识按namespace+id,类型为sql语句的类型
在这里插入图片描述
5、该方法为Select类型,接着判断方法返回值
在这里插入图片描述
6、以上都不成立,执行方法将方法参数转为sql命令的参数,进入该方法,再进入
在这里插入图片描述
7、此时不清楚names是什么,需要找出names
在这里插入图片描述
8、在该类ParamNameResolver找到names
在这里插入图片描述
9、该方法为names赋值
在这里插入图片描述
10、回到第7步,先看看传进去的真实参数
在这里插入图片描述
11、精华代码,含mybatis默认map的kv和自定义map的kv的设置
在这里插入图片描述
在这里插入图片描述

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Laptoy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值