mybatis的整体架构

作者 : 开心源码 本文共2068个字,预计阅读时间需要6分钟 发布时间: 2022-05-12 共77人阅读

mybatis的整体架构分为三层:

1.基础支持层

该层包括:数据源板块、事务管理板块、缓存板块、Binding板块、反射板块、类型转换板块、日志板块、资源加载板块、解析器板块

2.核心解决层

该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件

3.接口层

该层包括:SqlSession

基础支持层

该层保护mybatis的基础板块,它们为核心解决层提供了良好的支撑。

(1)反射板块

Mybatis中的反射板块,对Java原生的反射进行了很好的封装,提供了简易的API,方便上层调使用,并且对反射操作进行了一系列的优化,比方,缓存了类的元数据(MetaClass)和对象的元数据(MetaObject),提高了反射操作的性能。

(2)类型转换板块

Mybatis的别名机制,是为了简化配置文件的,该机制是类型转换板块的主要功能之一。类型转换板块的另一个功能是实现JDBC类型与Java类型间的转换。该功能在SQL语句绑定实参和映射查询结果集时都会涉及。在SQL语句绑定实参时,会将数据有Java类型转换成JDBC类型;在映射结果集时,会将数据有JDBC类型转换成Java类型。

(3)日志板块

Java世界里,有很多优秀的日志框架,如Log4j、Log4j2、slf4j等。Mybatis除了提供了详细的日志输出信息,还能够集成多种日志框架,其日志板块的主要功能就是集成第三方日志框架。

(4)资源加载板块

该板块主要封装了类加载器,确定了类加载器的用顺序,并提供了加载类文件和其它资源文件的功能。

(5) 解析器板块

该板块有两个主要功能:一个是封装了XPath,为Mybatis初始化时解析mybatis-config.xml配置文件以及映射配置文件提供支持;另一个为解决动态SQL语句中的占位符提供支持。

(6)数据源板块

在数据源板块中,Mybatis自身提供了相应的数据源实现,也提供了与第三方数据源集成的接口。数据源是开发中的常使用组件之一,很多开源的数据源都提供了丰富的功能,如,连接池、检测连接状态等,选择性能优秀的数据源组件,对于提供ORM框架以及整个应使用的性能都是非常重要的。

(7)事务管理板块

一般地,Mybatis与Spring框架集成,由Spring框架管理事务。但Mybatis自身对数据库事务进行了笼统,提供了相应的事务接口和简单实现。

(8)缓存板块

Mybatis中有一级缓存和二级缓存,这两级缓存都依赖于缓存板块中的实现。但是,需要注意,这两级缓存与Mybatis以及整个应使用是运行在同一个JVM中的,共享同一块内存,假如这两级缓存中的数据量较大,则可能影响系统中其它功能,所以需要缓存大量数据时,优先考虑用Redis、Memcache等缓存产品。

(9)Binding板块

在调使用SqlSession相应方法执行数据库操作时,需要制定映射文件中定义的SQL节点,假如sql中出现了拼写错误,那就只能在运行时才能发现。为了能尽早发现这种错误,Mybatis通过Binding板块将使用户自己设置的Mapper接口与映射文件关联起来,系统可以通过调使用自己设置Mapper接口中的方法执行相应的SQL语句完成数据库操作,从而避免上述问题。注意,在开发中,我们只是创立了Mapper接口,而并没有编写实现类,这是由于Mybatis自动为Mapper接口创立了动态代理商对象。有时,自己设置的Mapper接口可以完全代替映射配置文件,但比方动态SQL语句啊等,还是写在映射配置文件中更好。

核心解决层

(1)配置解析

在Mybatis初始化过程中,会加载mybatis-config.xml配置文件、映射配置文件以及Mapper接口中的注解信息,解析后的配置信息会形成相应的对象并保存到Configration对象中。之后,根据该对象创立SqlSessionFactory对象。待Mybatis初始化完成后,可以通过SqlSessionFactory创立SqlSession对象并开始数据库操作。

(2)SQL解析与scripting板块

Mybatis实现的动态SQL语句,几乎可以编写出所有满足需要的SQL。

Mybatis中scripting板块会根据使用户传入的参数,解析映射文件中定义的动态SQL节点,形成数据库能执行的sql语句。

(3)SQL执行

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

下图是一条sql语句执行的流程:

mybatis的整体架构

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » mybatis的整体架构

发表回复