mybatis原理之MapperMethod实现

MapperMethod是Mybatis中具体的数据访问执行方法入口,当mapper方法被调用的时候对应的MapperProxy会生成相应的MapperMethod并且会缓存起来,这样当多次调用同一个mapper方法时候只会生成一个MapperMethod,提高了时间和内存效率。每一个MapperMethod对应了一个mapper文件中配置的一个sql语句或FLUSH配置,对应的sql语句通过mapper对应的class文件名+方法名从Configuration对象中获得。


当执行MapperMethod的execute方法的时候,根据当前MapperMethod对应的mapper配置会执行Session的insert, update, delete, select,  selectList, selectMap, selectCursor, selectOne或flushStatements方法。 具体执行Session对象的哪个方法判定如下:



Mapper节点 session方法
insert insert
update update
delete delete
select select: 方法返回void,并且包含resultHandler配置时
select selectList:方法返回数组或Collection子类时候
select selectMap: 存在MapKey注解
select selectCursor: 方法返回Cursor
select selectOne 其它
flush Flush注解


创建Session对象需要传递的参数逻辑如下:


public Object convertArgsToSqlCommandParam(Object[] args) {
  final int paramCount = params.size();
  if (args == null || paramCount == 0) {
    return null;
  } else if (!hasNamedParameters && paramCount == 1) {
    return args[params.keySet().iterator().next()];
  } else {
    final Map param = new ParamMap();
    int i = 0;
    for (Map.Entry entry : params.entrySet()) {
      param.put(entry.getValue(), args[entry.getKey()]);
      // issue #71, add param names as param1, param2...but ensure backward compatibility
      final String genericParamName = "param" + String.valueOf(i + 1);
      if (!param.containsKey(genericParamName)) {
        param.put(genericParamName, args[entry.getKey()]);
      }
      i++;
    }
    return param;
  }
} 
  

这里args是用户mapper所传递的方法参数列表, 如果方法没有参数,则返回null.  如果方法只包含一个参数并且不包含命名参数, 则返回传递的参数值。如果包含多个参数或包含命名参数,则返回包含名字和对应值的map对象




你可能感兴趣的:(Mybatis)