Mybatis-plus核心类
1、MybatisSqlSessionFactoryBean
初始化Configuration(实际为MybatisConfiguration)
MybatisXMLConfigBuilder:内部会调动Mybatis的XMLConfigBuilder 初始化继承BaseMapper 的Mapper接口中的所有方法和对应的SqlSource(其中包含着执行的Sql语句)
2、GlobalConfiguration: Mybatis全局Configuration缓存
ISqlInjector(sql注入器)SqlSessionFactorymapperRegistryCache(缓存已注入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:数据库表反射信息
TableFieldInfoMap<String, TableInfo> tableInfoCache
6、MybatisMapperAnnotationBuilder
XMLMapperBuilder解析所有mapper.xml文件(mapper.xml文件中会自定义方法)创建ISqlInjector初始化继承了BaseMapper接口的所有接口的所有方法(这里只包含BaseMapper接口里的基础方法,而开发者自定义的方法已经通过XMLMapperBuilder解析创建好了)
7、MybatisSqlSessionTemplate:实现SqlSession
创建SqlSessionProxy代理各种基础数据库操作方法(增删改查等)
未完待续~
MyBatis-plus是如何实现为我们提供便捷的SQL方法的?如何利用MyBatis-plus的特性完成字段加解密?