前言
在上一篇文章Mybaits Sql解析过程中,笔者介绍了Mybatis是如何根据注解生成动态Sql语句的。但是,在常用的查询中,除了生成语句之外,为Sql查询语句添加参数也是非常重要的一个环节。
本篇文章将会对Mybatis参数解析,设置的全过程,进行分析。简单点来说,就是我们会围绕着一下的方法调用例子,了解Mybatis如何将方法中的参数转化为Sql中的参数。
@Select({
"<script>",
"SELECT account",
"FROM user",
"WHERE id IN",
"<foreach item='item' index='index' collection='list'",
"open='(' separator=',' close=')'>",
"#{item}",
"</foreach>",
"</script>"})
List<String> selectAccountsByIds(@Param("list") int[] ids);
Mybatis中的Sql参数设定与执行
首先,我们来通过一张简略的图片,来大概了解整个过程。
通过这张图,我们可以了解到几个重点。
通过MethodSignature将参数转化为Map
调用的具体方法如下
public Object getNamedParams(Object[] args) {
final int paramCount = names.size();
if (args == null || paramCount == 0) {
return null;
} else if (!hasParamAnnotation && paramCount == 1) {
return args[names.firstKey()];
} else {
final Map<String, Object> param = new ParamMap<Object>();
int i = 0;
for (Map.Entry<Integer, String> entry : names.entrySet()) {
//首先,