一、ORM简介
JDBC是Java与数据库交互的统一API.传统的JDBC编程的操作步骤如下:
- (1)、注册数据库驱动,明确指定数据库URL地址、数据库用户名、密码等连接信息
- (2)、通过DriverManager打开数据库连接
- (3)、通过数据库连接创建Statement对象
- (4)、通过Statement对象执行SQL语句,得到ResultSet对象
- (5)、通过ResultSet读取数据,并将数据转换成JavaBean对象
- (6)、关闭ResultSet、Statement对象以及数据库连接,释放相关资源
ORM(Object-Relational-Mapping)对象关系映射,将JavaBean和数据库对象进行相互的转换。
二、常见持久化框架
Hibernate、MyBatis、JPA、Spring JDBC
三、什么是MyBatis
MyBatis的前身是iBATIS,是Clinton-Begin在2001年发起的一个开源项目,最初侧重于密码软件的开发,后来发展成为一款基于Java的持久层框架。2004年Clinton将iBATIS的名字和源码捐赠给了Apache软件基金会,接下来的6年中,开源软件世界发生了巨大的变化, 一切开发实践、基础设施、许可,甚至数据库技术都彻底改变了。2010年核心开发团队决定离开Apache软件基金会,并且将iBATIS改名为MyBatis。
MyBatis是一款优秀的支持自定义SQL查询、存储过程和高级映射的持久层框架,消除了几乎所有的JDBC代码和参数的手动设置以及结果集的检索。MyBatis可以使用XML或注解进行配置和映射,MyBatis通过将参数映射到配置的SQL形成最终执行的SQL 语句,最后将执行SQL的结果映射成Java对象返回。
与其他的ORM(对象关系映射)框架不同,MyBatis并没有将Java对象与数据库表关联起来,而是将Java方法与SQL语句关联。MyBatis允许用户充分利用数据库的各种功能,例如存储过程、视图、各种复杂的查询以及某数据库的专有特性。如果要对遗留数据库、不规范的数据库进行操作,或者要完全控制SQL的执行,MyBatis将会是一个不错的选择。
与JDBC相比,MyBatis简化了相关代码,SQL语句在一行代码中就能执行。MyBatis提供了一个映射引擎,声明式地将SQL语句的执行结果与对象树映射起来。通过使用一种内建的类XML 表达式语言SQL 语句可以被动态生成。
四、Mybatis整体架构
MyBatis整体分为三层:基础支持层、核心处理层、接口层
五、Mybatis SQL执行流程
SQL语句的执行涉及各个组件,其中比较重要的是Executor,StatementHandler,ParameterHandler和ResultSetHandler。
Executor主要负责一级缓存和二级缓存,并提供是事务管理的相关操作,它会将数据库相关操作委托给StatementHandler完成,StatementHandler首先通过ParammeterHandler完成SQL的实参绑定,然后通过java.sql.Statement对象执行sql语句并得到结果集ResultSet,最后通过ResultSetHandler完成结果集的映射,得到对象并返回。如下图所示: