Mybatis-plus核心类
1、MybatisSqlSessionFactoryBean
- 初始化Configuration(实际为MybatisConfiguration)
- MybatisXMLConfigBuilder:内部会调动Mybatis的XMLConfigBuilder
- 初始化继承BaseMapper 的Mapper接口中的所有方法和对应的SqlSource(其中包含着执行的Sql语句)
2、GlobalConfiguration: Mybatis全局Configuration缓存
- ISqlInjector(sql注入器)
- SqlSessionFactory
- mapperRegistryCache(缓存已注入CRUD的Mapper信息)
- SqlSession
3、GlobalConfigUtils:Mybatis全局缓存工具类
- Map<String, GlobalConfiguration> GLOBAL_CONFIG = new ConcurrentHashMap<>()
- key 为Configuration的地址值,value为GlobalConfiguration
4、ISqlInjector:实现类AutoSqlInjector
- 实现CRUD注入,即将Mapper接口的方法和XML中自定义的SQL语句进行封装,并缓存到Configuration中。
- 这里的注入用到了GlobalConfigUtils中的缓存,避免同一个文件多次加载
- AutoSqlInjector.inject()方法实现CRUD注入(表field)
- 获取Mapper对应的Model类
- 初始化TableInfo、TableFieldInfo
- AutoSqlInjector.injectSql()方法注入SQL,SqlMethod枚举中已定义BaseMapper接口中各个方法对应的sql语句,只需要和TableInfo对应的字段进行拼接,使用LanguageDriver(XMLLanguageDriver)生成SqlSource(StaticSqlSource)
- 在解析数据库字段和Java对象的映射关系时,通过mapper接口找到其具体的TableInfo Java类,构建实体类反射获取表信息【初始化】
- 最后生成MappedStatement保存到Configuration中
5、TableInfo:数据库表反射信息
- TableFieldInfo
- Map<String, TableInfo> tableInfoCache
6、MybatisMapperAnnotationBuilder
- XMLMapperBuilder解析所有mapper.xml文件(mapper.xml文件中会自定义方法)
- 创建ISqlInjector
- 初始化继承了BaseMapper接口的所有接口的所有方法(这里只包含BaseMapper接口里的基础方法,而开发者自定义的方法已经通过XMLMapperBuilder解析创建好了)
7、MybatisSqlSessionTemplate:实现SqlSession
- 创建SqlSessionProxy代理
- 各种基础数据库操作方法(增删改查等)
未完待续~
- MyBatis-plus是如何实现为我们提供便捷的SQL方法的?
- 如何利用MyBatis-plus的特性完成字段加解密?