Mybatis获取mapper源码解析

大致流程:由IO流获取文件信息,再通过IO流去得到SqlSessionFactory,由SqlSessionFactory得到SqlSession,最后通过SqlSession获取到mapper

总体代码:

 String resource = "mybatis-config.xml";
        
        InputStream is = Resources.getResourceAsStream(resource);
        
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        
        SqlSession session = sqlSessionFactory.openSession();
        
        UserMapper mapper = session.getMapper(UserMapper.class);

具体细节:

1.

InputStream is = Resources.getResourceAsStream(resource);
public static InputStream getResourceAsStream(String resource) throws IOException {
    return getResourceAsStream(null, resource);
  }
 InputStream getResourceAsStream(String resource, ClassLoader[] classLoader) {
    for (ClassLoader cl : classLoader) {
      if (null != cl) {

        // try to find the resource as passed
        InputStream returnValue = cl.getResourceAsStream(resource);

        // now, some class loaders want this leading "/", so we'll add it and try again if we didn't find the resource
        if (null == returnValue) {
          returnValue = cl.getResourceAsStream("/" + resource);
        }

        if (null != returnValue) {
          return returnValue;
        }
      }
    }
    return null;
  }

                                                                          

  •    调用getResourceAsStream获取mybatis-config.xml。
  •    getResourceAsStream调用 getResourceAsStream(String resource) 。
  •     getResourceAsStream(String resource) 调用classLoaderWrapper下的getResourceAsStream(resource, loader)。
  •    最后由classLoader[ ] 实现

2. 

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
 public DefaultSqlSessionFactory(Configuration configuration) {
    this.configuration = configuration;
  }
public class DefaultSqlSessionFactory implements SqlSessionFactory
 public SqlSessionFactory build(Configuration config) {
    return new DefaultSqlSessionFactory(config);
  }

 

  •  build函数通过Xpath解析获得configuration.
  • 通过configuration得到DefaultSqlSessionFactory,
  • 再由 DefaultSqlSessionFactory获得SqlSessionFactory

3. 

  SqlSession session = sqlSessionFactory.openSession();
        
 public SqlSession openSession(ExecutorType execType, boolean autoCommit) {
    return openSessionFromDataSource(execType, null, autoCommit);
  }
private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) {
    Transaction tx = null;
    try {
      final Environment environment = configuration.getEnvironment();
      final TransactionFactory transactionFactory = getTransactionFactoryFromEnvironment(environment);
      tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit);
      final Executor executor = configuration.newExecutor(tx, execType);
      return new DefaultSqlSession(configuration, executor, autoCommit);
    } catch (Exception e) {
      closeTransaction(tx); // may have fetched a connection so lets call close()
      throw ExceptionFactory.wrapException("Error opening session.  Cause: " + e, e);
    } finally {
      ErrorContext.instance().reset();
    }
  }
  • 调用openSession().
  • openSession调用openSessionFromDataSource(exectype,null,autoComit),通过此函数获取事务,对应的执行器,事务自动提交      以及配置文件对象(Configuration)
  • 最后返回DefaultSqlSession。

4. 

  UserMapper mapper = session.getMapper(UserMapper.class);
 @Override
  public <T> T getMapper(Class<T> type) {
    return configuration.<T>getMapper(type, this);
  }

调用函数getMapper得到mapper.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值