提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
- 什么是框架?
- 一、MyBatist框架简介
- 二、查看步骤
- 1.加载核心配置文件到Configuratio
- 2.构建SqlSessionFactory
- 3.打开SqlSession会话
- 4.Executor开始处理请求(执行器)
- 5.SqlSource解析SQL语句
- 6.StatementHandler执行SQL语句
- 7.ParameterHandler设置参数
- 8.StatementHandler执行SQL语句
- 9.ResultSetHandler处理结果集
- 总结
什么是框架?
软件框架是一种通用的、可复用的软件环境,它提供特定的功能,作为一个更大的软件平台的一部分,用以促进软件应用、产品和解决方案的开发工作。软件框架可能会包含支撑程序、编译器、代码、库、工具集以及 API,它把所有这些部件汇集在一起,以支持项目或系统的开发。
一、MyBatist框架简介
MyBatis是一个优秀的基于Java的持久层框架,内部封装了jdbc,开发者仅需关注sql语句本身,不需要花更多的精力去处理加载驱动、创建连接、创建statement等繁杂的过程。
MyBatis通过注解或xml配置的方式将需要执行的statement配置起来,并通过Java对象和statement中sql的动态参数进行映射生成最终需要执行的sql语句,最后由Mybatis框架执行sql语句并将结果映射为Java对象并返回。
二、查看步骤
1.加载核心配置文件到Configuration
Configuration类是整个MyBatist框架运行的核心配置,包含所有Mapper、别名、SQL等信息:
Resultmaps保存了所有解析到了《resultmap》节点。
MappedStatement保存了所有解析到的增删改查的SQL节点。
TypeAliasRegistry是所有类型别名的注册表,包括Java语言本身的类型别名、业务实体类。
代码如下(源码):
2.构建SqlSessionFactory
代码如下(源码):
这里MyBatist采用了构造者模式通过xml的方式实例化一个SqlSessionFactory对象。其核心思想就是想把config.xml和所有的Mapper.xml解析,然后封装到configuration对象中。
3.打开SqlSession会话
SqlSession的获取主要是通过SqlSessionFactory接口的实现类DefaultSqlSessionFactory中的openSessionFromDataSource方法获取
代码如下(源码):
4.Executor开始处理请求(执行器)
XMLConfigBuilder是一个解析核心配置的解析器类:
parse()解析并封装所有核心配置和Mapper信息,得到一个configuration对象
MappedStatement是对所有所有SQL语句的封装
代码如下(源码):
5.SqlSource解析SQL语句
6.StatementHandler执行SQL语句
7.ParameterHandler设置参数
代码如下(源码):
8.StatementHandler执行SQL语句
9.ResultSetHandler处理结果集
代码如下(源码):
总结
通过对MyBatist源码的分析,可以深入了解此框架的执行过程,解决我们开发中的问题