Mybatis深入源码分析之SqlSessionFactoryBuilder

Mybatis是支持定制化SQL、存储过程和高级映射的持久层框架。主要完成两件事:封装JDBC的操作 利用反射完成Java类和SQL之间的转换mybatis的主要目的就是管理执行SQL是参数的输入和输出,编写SQL和结果集的映射是mybatis的主要优点1.Mybatis大体架构流程分析读取配置文件并返回Reader对象 使用SqlSessionFactoryBuilder获取S...
摘要由CSDN通过智能技术生成

Mybatis是支持定制化SQL、存储过程和高级映射的持久层框架。主要完成两件事:

  • 封装JDBC的操作
  • 利用反射完成Java类和SQL之间的转换

mybatis的主要目的就是管理执行SQL是参数的输入和输出,编写SQL和结果集的映射是mybatis的主要优点

1.Mybatis大体架构流程分析

  1. 读取配置文件并返回Reader对象
  2. 使用SqlSessionFactoryBuilder获取SqlSessionFactory源码分析
  3. 创建session
  4. 获取相对应mapper
    try {
            // 1.mybatis配置文件
            String resources = "mybatis.xml";
            // 2.获取Reader对象
            Reader resourceAsReader = Resources.getResourceAsReader(resources);
            // 3.获取SqlSessionFactoryBuilder
            SqlSessionFactory build = new SqlSessionFactoryBuilder().build(resourceAsReader);
            // 4.创建对应的session
            SqlSession sqlSession = build.openSession();
            // 5.获取对应的mapper
            UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
            // 6.执行方法
            UserEntity user = userMapper.getUser(1);
            System.out.println("name:" + user.getName());
        } catch (Exception e) {
            e.printStackTrace();
        }

1.1类图

2.源码分析

2.1获取Reader对象

   Reader resourceAsReader = Resources.getResourceAsReader(resources);

public static Reader getResourceAsReader(String resource) throws IOException {
    Reader reader;
    if (charset == null) {
      reader = new InputStreamReader(getResourceAsStream(resource));
    } else {
      reader = new InputStreamReader(getResourceAsStream(resource), charset);
    }
    return reader;
  }

通过resource(配置文件路径)获取reader对象

2.2获取SqlSessionFactory

 SqlSessionFactory build = new SqlSessionFactoryBuilder().build(resourceAsReader);

1.进入到SqlSessionFactoryBuilder().build(resourceAsReader)方法

  public SqlSessionFactory build(Reader reader) {
    return build(reader, null, null);
  }

2.进入源码最终执行的方法是

  public SqlSessionFactory build(Reader reader, String environment, Properties properties) {
    try {
      //XMLConfigBuilder是对mybatis的配置文件进行解析的类,会对myabtis解析后的信息存放在Configuration对象中
      XMLConfigBuilder parser = new XMLConfigBuilder(reader, environment, properties);
      return build(parser.parse());
    } catch (Exception e) {
      throw ExceptionFactory.wrapException("Error building SqlSession.", e);
    } f
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值