一、简介:
- MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。
- iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO)
- MyBatis的前身就是iBatis,iBatis本是由ClintonBegin开发,后来捐给Apache基金会,成立了iBatis开源项目。2010年5月该项目由Apahce基金会迁移到了GoogleCode,并且改名为MyBatis。尽管如此,它的包结构仍然为ibatis。
- 访问网站
- MyBatis是一个数据持久层(ORM)框架。把实体类和SQL语句之间建立了映射关系,是一种半自动化的ORM实现。
- 所有sql语句,全部定义在xml(建议)中。也可以通过注解的方式在接口上实现。这些映射文件称之为mapper。
二、MyBatis的优点(与其他架构区别)
- MyBatis的优点:
-
- 基于SQL语法,简单易学。
- 能了解底层组装过程。
- SQL语句封装在配置文件中,便于统一管理与维护,降低了程序的耦合度。
- 程序调试方便。
-
- 与传统JDBC的比较
-
-
减少了61%的代码量
-
最简单的持久化框架
-
架构级性能增强
-
SQL代码从程序代码中彻底分离,可重用
-
增强了项目中的分工
-
增强了移植性
-
-
- 与Hibernate的对比
- Mybatis 在XML文件中配置SQL语句,实现了SQL语句和代码的分离,给程序的维护带来了很大便利
MyBatis |
Hibernate |
是一个SQL语句映射的框架(工具) | 主流的ORM(对象关系映射)框架、提供了从POJO到数据库表的全套映射机制 |
注重POJO/Map与SQL之间的映射关系。不会为程序员在运行期自动生成SQL | 会自动生成全套SQL语句。 |
自动化程度低、手工映射SQL,灵活程度高 | 因为自动化程度高、映射配置复杂,api也相对复杂,灵活性低. |
需要开发人员熟炼掌据SQL语句 | 开发人同不必关注SQL底层语句开发 |
三、Mybatis 体系结构
1.功能架构讲解:
我们把Mybatis的功能架构分为三层:
- API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。
- 数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。
- 基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。
2.框架架构讲解:
-
加载配置:配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个mybatis结构个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。
-
SQL解析:当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以是Map、JavaBean或者基本数据类型),Mybatis会根据SQL的ID找到对应的MappedStatement,然后根据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数。
-
SQL执行:将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果。
-
结果映射:将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap、JavaBean或者基本数据类型,并将最终结果返回。
四、Mybatis 工作原理