世界上只有两种人,懒人和漫无目的的人,作为一名工程师如果不勤奋且没有目标,淘汰是必然的
学无止境 点我 跳转到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的设置