Mybatis体系结构:
Mybatis的功能架构分为三层:
- API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请 求就会调用数据处理层来完成具体的数据处理。
- 数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调 用的请求完成一次数据库操作。
- 基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。
Mybatis工作流程
1、加载配置
配置有两种方式,一种是XML文件配置,另一种是java代码的注解。Mybatis将sql的配置信息加载成为 一个个的MappedStatement对象(包括了传入参数映射配置,执行事物SQL语句,结果映射配置),将其 存储再内存中。
2、Sql解析
当API接口层接收到调用请求时,会接收传入sql的Id和传入对象(可以是Map,javaBean或者基本数 据类型),Mybatis会根据Sql的的Id查找到相应的的MappedStatement,然后根据传入的参数对象对
MappedStatement对象进行解析,解析后便得到了最终需要执行的Sql语句和参数。
3、Sql执行
将最终得到的Sql和参数拿到数据库进行执行,得到需要的结果。
4、结果映射
将操作得到的数据库的结果按照映射配置进行转换,可以将其转换成HashMap,javaBean 或者基本数据类型,并将最终的结果返回。
Mybatis核心部件
- Configuration :MyBatis所有的配置信息都保存在Configuration对象之中,配置文件中的大部分配置都会存 储到该类中
- SqlSession :作为MyBatis工作的主要顶层API,表示和数据库交互时的会话,完成必要数据库增删改查功能
- Executor :MyBatis执行器,是MyBatis 调度的核心,负责SQL语句的生成和查询缓存的维护,有他来实现真 正对数据库的操作。
- StatementHandler :封装了JDBC Statement操作,负责对JDBC statement 的操作,如设置参数等
- ParameterHandler : 负责对用户传递的参数转换成JDBC Statement 所对应的数据类型
- ResultSetHandler : 负责将JDBC返回的ResultSet结果集对象转换成List类型的集合
- TypeHandler: 负责java数据类型和jdbc数据类型(也可以说是数据表列类型)之间的映射和转换
- MappedStatement : 其维护着一条<select | update| delete| insert>节点的封装 (就是我们map.xml中定 义哪些操作)
原文地址:https://www.cnblogs.com/ericz2j/p/11108063.html
时间: 2024-10-08 08:30:47