【Mybatis源码】源码分析

(1)Mybatis简介

Mybatis框架绕过我们使用起来更加简单,只需要通过调用Mapper接口的方法并且在mapper.xml中编写对应的sql语句来完成工作,只是Mybatis在JDBC的基础上进行了封装,让我们不需要关心connect对象的创建、statement对象的创建、参数的设置、结果集处理等等。Mybatis把这些步骤都封装成了一个个组件去完成对应的工作。

(1)原生jdbc查询代码

public static void main(String[] args) throws Exception {
    Class.forName("com.mysql.jdbc.Driver");
    // 获取数据库连接对象
    Connection conn=  DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test","root","123456");

    String sql="select * from emp where empno = ?";
    // 创建Statement对象
    PreparedStatement stm = conn.prepareStatement(sql);
    // 参数设置
    stm.setInt(1, 7369);
    // 执行查询,结果返回到ResultSet
    ResultSet rs = stm.executeQuery();

    // 处理结果集
    while(rs.next()){
      System.out.println(rs.getInt("empno"));
      System.out.println(rs.getString("ename"));
    }
    conn.close();
  }

(2)使用Mybatis查询代码

  public static void main(String[] args) throws Exception {
  	// 配置文件
    String resource = "mybatis-config.xml";
    InputStream inputStream = Resources.getResourceAsStream(resource);
    // 生成SqlSessionFactory
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
    // 打开回话
    SqlSession sqlSession = sqlSessionFactory.openSession();
    // 获取代理类
    EmpDao mapper = sqlSession.getMapper(EmpDao.class);
    // 通过代理类调用查询方法
    Emp empByEmpno = mapper.findEmpByEmpno(7369);
    // 关闭会话
    sqlSession.close();
  }

(2)MyBatis中重要组件

请添加图片描述

(3)MyBatis的源码分析

(1)准备工作

(1)创建Configuration对象

Configuration对象是全局的配置对象,SqlSessionFactory、SqlSession都包含了该对象,可以说该整个查询过程中都可能会用到该对象。
(1)Configuration对象源码概述
1-解析给定的配置文件,加载配置文件中的配置属性设置到Configuration中
2-解析环境对象标签,设置到environment属性中,Environment对象包含了包含了TransactionFactory、DataSource
3-解析日志相关标签并设置logImpl实现类
4-Configuration对象如果不指定执行器,默认为简单的执行器SimpleExecutor
5-解析配置的mappers包,并将每个Mapper接口生成一个MapperProxyFactory并放到mapperRegistry 属性中,方便下次用时获取。
6-第五步的同时,它会去解析每个mapper.xml文件的各个增删改查标签,每个语句都会构建成一个MappedStatement对象,并缓存到mappedStatements集合中。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值