mybatis (整体架构) (一)

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。


1.mybatis架构


分为3层: 1.接口层 2.数据处理层 3.框架支撑层

2.接口层

接口层是对外的的api,主要使用sqlSession接口,通过`sqlsession接口`、`mapper接口`,开发人员可以通知mysql调用哪一条sql以及相关参数

sqlsession接口使用方式

使用传统的Mybatis提供的Api接口, 根据Statement Id使用接口


mapper接口使用方式

jdk动态代理的方式


3.数据处理层

根据调用的请求完成一次的数据库操作:

Sql查找:参数的映射, ParameterHandler

Sql解析: SqlSource

Sql执行: Executor

执行结果映射处理: ResultSetHandler

4.支撑层

为上层的数据处理层提供基础的支撑:

mybatis和数据库的连接方式管理:DataSource + Connection

mybatis事务的管理:ransactionFactory + Transaction

sql和xml映射方式管理,配置的管理: Configuration

mybatis缓存管理: 一级缓存 + 二级缓存

5.mybatis的调用流程


`SqlSession`: 接收开发人员的statement id和参数,并返回查询结果

`Executor:` 执行器,是mybatis核心的调度器,负责sql动态语句的生成和参数,查询缓存的维护

`StatementHandler`: 负责jdbc和statement的交互,包括statement设置参数、结果转化

`ParameterHandler`: 将用户传入的参数转化为statement需要的参数

`ResultSetHandler`: 将jdbc返回的ResultSet结果转化为List类型集合

`TypeHandler`: 负责java数据类型和jdbc数据类型进行转化

`MappedStatement`: 维护了一条节点的封装

`SqlSource`: 根据用户传递的parameterObject, 动态的生成Sql,将信息封装到BoundSql对象中

`BoundSql`: 动态生成的Sql语句以及对应的参数信息

你可能感兴趣的:(mybatis (整体架构) (一))