MyBatis简介


一、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整体分为三层:基础支持层、核心处理层、接口层

img

五、Mybatis SQL执行流程

SQL语句的执行涉及各个组件,其中比较重要的是Executor,StatementHandler,ParameterHandler和ResultSetHandler。
 Executor主要负责一级缓存和二级缓存,并提供是事务管理的相关操作,它会将数据库相关操作委托给StatementHandler完成,StatementHandler首先通过ParammeterHandler完成SQL的实参绑定,然后通过java.sql.Statement对象执行sql语句并得到结果集ResultSet,最后通过ResultSetHandler完成结果集的映射,得到对象并返回。如下图所示:

img

参考链接:https://juejin.im/post/6844903789531496456


文章作者: nfLJ
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 nfLJ !
评论
 上一篇
Java注解(Annotation) Java注解(Annotation)
概念Java 注解(Annotation)又称 Java 标注,是 JDK5.0 引入的一种注释机制。Java 语言中的类、方法、变量、参数和包等都可以被标注。和 Javadoc 不同,Java 标注可以通过反射获取标注内容。在编译器生成类
2020-08-13
下一篇 
Spring面试常见问题 Spring面试常见问题
1.什么是 Spring 框架?Spring是一个轻量级Java开发框架,最早有Rod Johnson创建,目的是为了解决企业级应用开发的业务逻辑层和其他各层的耦合问题。它是一个分层的JavaSE/JavaEE full-stack(一站式
2020-08-11
  目录