Mybatis技术内幕——笔记(1)
第一章——快速入门
ORM简介
传统JDBC编程
主要步骤:
1.注册驱动
2.通过DriverManager打开数据库连接
3.通过数据库连接创建Statement对象(预执行语句对象)
4.通过Statement对象执行SQL,得到ResultSet结果对象
5.ResultSet结果对象转换成JavaBean对象
6.关闭连接、释放资源
重点是第5点
1-6的步骤都可以通过一个工具类去操作,因 为都是通用的。但第5点无法通用,不同结果或者相同结果映射的JavaBean都可能不同。
所以出现了ORM框架
常见持久化框架
- Hibernate
- JPA
- Spring JDBC
- Mybatis
Mybatis 示例
Mybatis的配置文件
加载、使用
1.加载,InputStream
2.根据文件里的配置创建SqlSessionFactory
3.SqlSession创建SqlSesson
4.SqlSession执行SQL
5.SqlSession提交事务
6.关闭SqlSession对象
Mybatis 整体架构
整体架构分为三层:基础支持层,核心处理层,接口层
基础支持层
反射模块
对Java反射进行了良好封装,提供了更加简洁易用的API,方便调用,并对反射操作进行了一系列优化。
类型转换模块
主要功能:
- 别名机制(为简化配置文件)
- 实现JDBC类型与Java类型间的转换
日志模块
主要功能就是集成第三方日志框架
资源加载模块
主要是对类加载器进行封装,确定类加载器的使用顺序,并提供加载文件以及其他资源文件的功能。
Resources类封装了类加载器。
解析器模块
例如:XPathParser类
主要功能:
- 对XPath进行封装
- 为处理动态SQL语句中的占位符提供支持
数据源模块
优秀的数据源组件能提升ORM框架乃至整个应用的性能。
主要是提供相应的数据源实现,还提供了与第三方数据源集成的接口。
事务管理
提供了事务接口和简单实现。现在多数事务由Spring框架管理,所以主要是事务接口与Spring的集成
缓存模块
主要是优化数据库性能
Mybatis提供了一级缓存和二级缓存。
注意!
Mybatis中自带的这两级缓存与Mybatis以及整个应用是运行在同一个JVM中的,共享同一块堆内存。
所有缓存数据量过大,可能会影响系统中其他功能。所以优化考虑使用Redis、Memcashe等缓存产品。
Binding模块
Binding模块将用户自定义的Mapper接口与映射配置文件关联起来,系统可以通过调用自定义Mapper接口中的方法执行相应的SQL语句。
其实我还是有点不太明白,所以后面还要去了解一下
核心处理层
在核心处理层中,实现了Mybatis的核心处理流程,其中包括Mybatis的初始化以及完成一次数据库操作的涉及的全部流程
配置解析
初始化过程中,加载Mybatis-config.xml配置文件、映射配置文件、Mapper接口中的注解信息,解析后会形成相应的对象保存到Configuration对象中。
SQL解析与scriptin模块
拼凑SQL语句、<where>,<if>,<foreach>等的动态生成。
SQL执行
SQL的执行涉及多个组件。
Executor主要负责维护一、二级缓存,并提供事务管理相关操作,它会将数据库相关操作委托给StatementHandler完成。
StatementHandler通过ParameterHandler完成SQL语句的实参绑定,然后通过java.sql.Statement执行SQL并得到结果集,最后通过ResultSetHandler完成结果集映射交返回对象。
插件
Mybatis并不能完美切合所有应用场景,因此可以利用插件对Mybatis进行扩展。但要注意,别让插件影响到Mybatis。
接口层
核心是SqlSession接口
定义了Mybatis暴露给应用程序调用的API