mybatis的运行原理

MyBatis框架在操作数据库时,大体经过了8个步骤:
1.读取 MyBatis 配置文件:mybatis-config.xml 为 MyBatis 的全局配置文件,配置了 MyBatis 的运行环境等信息,例如数据库连接信息。

2.加载映射文件:映射文件即 SQL 映射文件,该文件中配置了操作数据库的 SQL 语句,需要在 MyBatis 配置文件 mybatis-config.xml 中加载。mybatis-config.xml 文件可以加载多个映射文件,每个文件对应数据库中的一张表。

3.构造会话工厂:通过 MyBatis 的环境等配置信息构建会话工厂 SqlSessionFactory。

4.创建会话对象:由会话工厂创建 SqlSession 对象,该对象中包含了执行 SQL 语句的所有方法,是一个既可以发送sql执行并返回结果的,也可以获取mapper的接口

5.Executor 执行器:MyBatis 底层定义了一个 Executor 接口来操作数据库,它将根据 SqlSession 传递的参数动态地生成需要执行的 SQL 语句,同时负责查询缓存的维护。

6.MappedStatement 对象:在 Executor 接口的执行方法中有一个 MappedStatement 类型的参数,该参数是对映射信息的封装,用于存储要映射的 SQL 语句的 id、参数等信息。

7.输入参数映射:输入参数类型可以是 Map、List 等集合类型,也可以是基本数据类型和 POJO 类型。输入参数映射过程类似于 JDBC 对 preparedStatement 对象设置参数的过程。

8.输出结果映射:输出结果类型可以是 Map、 List 等集合类型,也可以是基本数据类型和 POJO 类型。输出结果映射过程类似于 JDBC 对结果集的解析过程。

   

      mybatis-config.xml   //配置文件
          mapper.xml   mapper.xml  mapper.xml
                       |
                       |
                   Resources  //对象加载配置文件通过getResourceAsStream()方法将配置信息输出为                           |                                 inputStream流
                       |
                       |---->inputStream  //得到一个输入流
                       |
               SqlSessionFactoryBuilder   //通过将得到的inputstream流对象信息封装到                                               |                         Configuration 对象中,创建sqlSessionFactory工厂对象
                       |
                       |--->Configuration(conn, Map<namespace+id, MappedStatement(sql,resultType)>)
                       |        //(MeapeedStatement封装SqL语句和查询结果集)

                       |
                  SqlSessionFactory   //创建SqlSession数据库会话对象
                       |
                       |--->Configuration(conn, Map<namespace+id, MappedStatement(sql,resultType)>)          
                       |
                  SqlSession    //该对象包含Sq2语句的所有方法,可以发送sq2执行和返回结果,也可|                         |                 //以获取mapper接口
                       |
                       |--->Map<namespace+id, MappedStatement(sql,resultType)>, conn
                       |
                   ProxyFactory   //代理工厂调用
                       |
                       |--->mappedStatement,conn
                       |
     Executor //通过SqlSession传递的参数动态生成需要执行的sq2语句,同时负责查询缓存的维护

                   |      |
                   |      |
                   |      | 

 输入参数映射  输出结果映射

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zz愿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值