9.Mybatis架构原理

9.1架构设计

我们把 Mybatis 的功能架构分为三层:
(1) API 接⼝层:提供给外部使⽤的接⼝ API ,开发⼈员通过这些本地 API 来操纵数据库。接⼝层⼀接收
到 调⽤请求就会调⽤数据处理层来完成具体的数据处理。
MyBatis 和数据库的交互有两种⽅式:
a. 使⽤传统的 MyBati s 提供的 API
b. 使⽤ Mapper 代理的⽅式
(2) 数据处理层:负责具体的 SQL 查找、 SQL 解析、 SQL 执⾏和执⾏结果映射处理等。它主要的⽬的是根
据调⽤的请求完成⼀次数据库操作。
(3) 基础⽀撑层:负责最基础的功能⽀撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是
共 ⽤的东⻄,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的⽀撑
 

9.2主要构件及其相互关系

9.3总体流程

(1) 加载配置并初始化
触发条件: 加载配置⽂件
配置来源于两个地⽅,⼀个是配置⽂件 ( 主配置⽂件 conf.xml,mapper ⽂件 *.xml),— 个是 java 代码中的
注解,将主配置⽂件内容解析封装到 Configuration, sql 的配置信息加载成为⼀个 mappedstatement
对象,存储在内存之中 (2) 接收调⽤请求
触发条件 :调⽤ Mybatis 提供的 API
传⼊参数:为 SQL ID 和传⼊参数对象
处理过程: 将请求传递给下层的请求处理层进⾏处理。
(3) 处理操作请求
触发条件: API 接⼝层传递请求过来
传⼊参数:为 SQL ID 和传⼊参数对象
处理过程:
(A) 根据 SQL ID 查找对应的 MappedStatement 对象。
(B) 根据传⼊参数对象解析 MappedStatement 对象,得到最终要执⾏的 SQL 和执⾏传⼊参数。
(C) 获取数据库连接,根据得到的最终 SQL 语句和执⾏传⼊参数到数据库执⾏,并得到执⾏结果。
(D) 根据 MappedStatement 对象中的结果映射配置对得到的执⾏结果进⾏转换处理,并得到最终的处
理 结果。
(E) 释放连接资源。
(4) 返回处理结果
将最终的处理结果返
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值