Configuration 是整个MyBatis的配置体系集中管理中心,前文所说的Executor、StatementHandler、Cache、MappedStatement…等绝大部分组件都是由它直接或间接的创建和管理。此外影响这些组件行为的属性配置也是由它进行保存和维护。如cacheEnabled、lazyLoadingEnabled … 等。所以说它MyBatis的大管家很形象。
Configuration是MyBatis中极其重要的一个类,它代表MyBatis的全局配置信息。
Configuration中包含了很多关键信息,主要包括:
Configuration保存的所有这些信息构成了MyBatis一次会话(SqlSession)的全部配置环境。每开启一个新的 SqlSession 都会根据 Configuration 来构建出 SqlSession 需要的所有信息。
所以简而言之,Configuration存储了MyBatis的全局配置信息,代表了一个MyBatis配置环境,它包含了SQL映射语句、结果集映射、缓存机制等等信息,这些信息构成了一个MyBatis一次会话需要的所有配置内容。
当我们调用SqlSessionFactoryBuilder.build(reader)
构建SqlSessionFactory时,底层会根据配置文件来构建一个Configuration对象。
当我们调用openSession()
开启一个会话时,SqlSession由一个Configuration以及执行器(Executor)组成,这个Configuration就是前面构建的全局配置信息。
所以可以看出,Configuration对MyBatis来说意义重大,它包含了MyBatis会话所需要的全部配置资源和环境信息。没有Configuration,则根本无法构建SqlSession,也就无法工作了。
Configuration 配置来源有三项:
然后我们再说说Configuration的核心作用:
这里我们为什么要使用Configuration进行Executor的创建?原因如下:
1、根据配置的类型创建
2、是否开启缓存
3、使用interceptorChain引入插件
其他几个组件的创建也是一样:
我们来说说几个组件:
mapperRegistry
用来注册mapper接口,并生成其动态代理对象。
caches
缓存,应用级跨会话的,所有的缓存装载好了之后都会放在Configuration里面。然后mappedStatement会与我们的缓存做一个关联操作,并且他们俩之间是1:1的关系。
TypeAliasRegistry
TypeAliasRegistry是MyBatis中用于保存类型别名的注册中心。
在MyBatis中,我们可以使用
标签来为Java类型配置别名,如:
<typeAlias type="com.someapp.model.User" alias="User"/>
这会使User成为com.someapp.model.User类型的别名,在后续映射文件中可以直接使用User来代表那个类型。
那么,MyBatis是如何实现这个类型别名功能的呢?
这就要依赖TypeAliasRegistry了
配置,并将找到的类型别名注册到这个注册中心。所以,TypeAliasRegistry的作用就是用来保存类型别名配置,并让MyBatis在需要时可以查找并使用这些别名。它实现了MyBatis的类型别名功能。
TypeAliasRegistry作为MyBatis的核心组件之一,主要有以下作用:
Configuration 配置信息来源于xml和注解,每个文件和注解都是由若干个配置元素组成,并呈现嵌套关系,总体关系如下图所示:
关于各配置的使用请参见官网给出文档:https://mybatis.org/mybatis-3/zh/configuration.html#properties
无论是XML还是我注解这些配置元素最弱都要被转换成JAVA配置属性或对象组件来承载。其对应关系如下:
或@Select
等由MappedStatement对象承载
或@CacheNamespace
由Cache对象承载配置文件解析需要我们分开讨论,首先来分析XML解析过程。xml配置解析其底层使用dom4j先解析成一棵节点树,然后根据不同的节点类型与去匹配不同的解析器。最终解析成特定组件。
解析器的基类是BaseBuilder 其内部包含全局的Configuration 对象,这么做的用意是所有要解析的组件最后都要集中归属至Configuration。接下来了解一下每个解析器的作用:
整体解析流程是从XmlConfigBuilder 开始,然后逐步向内解析,直到解析完所有节点。我们通过一个MappedStatement 解析过程即可了解到其整体解析流程。
流程说明:
【XmlConfigBuilder】 接收一个config.xml 输入流,然后创建一个空Configuration对象
【XmlConfigBuilder】解析全局配置
【XmlConfigBuilder】mapperElements解析,通过Resource或url 指定mapper.xml文件
注解解析底层实现是通过反射获取Mapper接口当中注解元素实现。有两种方式:
这些逻辑均由Mapper注册器(MapperRegistry)实现。其接收一个接口类参数,并基于该参数创建针对该接口的动态代理工厂,然后解析内部方法注解生成每个MapperStatement 最后添加至Configuration 完成解析。
想了解更多可参考文章:
MyBatis 核心配置综述之 Configuration详解
Mybatis主配置—Configuration