Mybatis框架

一、Mybatis框架基本概念

1.概述:
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
2.特点:

  • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
  • 提供映射标签,支持对象与数据库的orm字段关系映射
  • 提供对象关系映射标签,支持对象关系组建维护
  • 提供xml标签,支持编写动态sql。

3.具体流程:
(1)加载配置并初始化
触发条件:加载配置文件
处理过程:将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。
(2)接收调用请求
触发条件:调用Mybatis提供的API
传入参数:为SQL的ID和传入参数对象
处理过程:将请求传递给下层的请求处理层进行处理。
(3)处理操作请求
触发条件:API接口层传递请求过来
传入参数:为SQL的ID和传入参数对象
处理过程:
(A)根据SQL的ID查找对应的MappedStatement对象。
(B)根据传入参数对象解析MappedStatement对象,得到最终要执行的SQL和执行传入参数。
©获取数据库连接,根据得到的最终SQL语句和执行传入参数到数据库执行,并得到执行结果。
(D)根据MappedStatement对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果。
(E)释放连接资源。
(4)返回处理结果将最终的处理结果返回。
4.功能架构
Mybatis框架_第1张图片
(1)API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。
(2)数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。
(3)基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。
5.框架架构
Mybatis框架_第2张图片
(1)加载配置:配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。
(2)SQL解析:当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以是Map、JavaBean或者基本数据类型),Mybatis会根据SQL的ID找到对应的MappedStatement,然后根据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数。
(3)SQL执行:将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果。
(4)结果映射:将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap、JavaBean或者基本数据类型,并将最终结果返回。
6.主体架构

  • SqlMapperConfig.xml(核心配置文件) : sqlSessionFactory 和 sqlsession
  • Mapper.xml(动态sql的语句实现)

动态SQL:
MyBatis 最强大的特性之一就是它的动态语句功能。如果您以前有使用JDBC或者类似框架的经历,您就会明白把SQL语句条件连接在一起是多么的痛苦,要确保不能忘记空格或者不要在columns列后面省略一个逗号等。动态语句能够完全解决掉这些痛苦。
尽管与动态SQL一起工作不是在开一个party,但是MyBatis确实能通过在任何映射SQL语句中使用强大的动态SQL来改进这些状况。动态SQL元素对于任何使用过JSTL或者类似于XML之类的文本处理器的人来说,都是非常熟悉的。在上一版本中,需要了解和学习非常多的元素,但在MyBatis 3 中有了许多的改进,现在只剩下差不多二分之一的元素。MyBatis使用了基于强大的OGNL表达式来消除了大部分元素。

  • MappedStatement(方便动态加载Sql,用于绑定参数和返回值的封装)
  • DB(数据库)

二、常见的持久层框架及区别

在 java 应用的数据库开发中,不可避免地会使用到持久层框架,而现在开源项目中持久层框架用到最多的基本就是 iBatis、myBatis 和 Hibernate 了。

有关这三个框架区别的详细介绍请参考资料:
https://blog.csdn.net/weixin_42131983/article/details/81322029

接下来说一下Mybatis 和 Hibernate 和 JDBC 的使用区别:

  • JDBC: 所有的持久层框架都是在JDBC的基础上进行优化封装的。
    好处: 单个操作效率高。
    缺点:参数绑定,返回值的封装。
  • Hibernate: 在JDBC的基础上进行高度封装,不用编写sql,即可映射数据库。擅长针对复杂的多表关系,可以方便关联操作,场景: 业务和实体之间关联,Hibernate比较擅长处理,不擅长: 复杂的关联关系。
    实例: OA,政府档案,数据管理系统
  • Mybatis: 在JDBC的基础上进行完美的封装,保留了JDBC动态sql的编写,优化了参数的绑定和返回指的封装。
    实例: 网上电商,网络金融

三、第一个Mybatis 程序编写步骤

1.创建项目,导入jar包
Mybatis框架_第3张图片
在项目的src目录下创建一个lib包用于存放我们所需要的jar包文件,并将我们所给的jar包复制粘贴到lib包下然后选中所有jar包鼠标右击选择
add as library…
导入到我们的项目中。
Mybatis框架_第4张图片
Mybatis框架_第5张图片
出现上图所示效果则jar包导入成功。

2.SqlMapperConfig.xml配置文件,编写数据库的连接配置
Mybatis框架_第6张图片
3.测试数据库是否连接正常
Mybatis框架_第7张图片
4.编写Mapper.xml中的动态sql
Mybatis框架_第8张图片
5.测试SQL执行操作是否正常
Mybatis框架_第9张图片

你可能感兴趣的:(java)