日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解Mybatis是如何解析配置文件的

瀏覽:184日期:2023-10-20 16:01:16
緣起

經過前面三章的入門,我們大概了解了Mybatis的主線邏輯是什么樣子的,在本章中,我們將正式進入Mybatis的源碼海洋。

Mybatis是如何解析xml的構建Configuration

詳解Mybatis是如何解析配置文件的

我們調用new SqlSessionFactoryBuilder().build()方法的最終目的就是構建 Configuration對象,那么Configuration何許人也?Configuration對象是一個配置管家, Configuration對象之中維護著所有的配置信息。Configuration的代碼片段如下

public class Configuration { //環境 protected Environment environment; protected boolean safeRowBoundsEnabled; protected boolean safeResultHandlerEnabled = true; protected boolean mapUnderscoreToCamelCase; protected boolean aggressiveLazyLoading; protected boolean multipleResultSetsEnabled = true; protected boolean useGeneratedKeys; protected boolean useColumnLabel = true; protected boolean cacheEnabled = true; protected boolean callSettersOnNulls; protected boolean useActualParamName = true; protected boolean returnInstanceForEmptyRow; //日志信息的前綴 protected String logPrefix; //日志接口 protected Class<? extends Log> logImpl; //文件系統接口 protected Class<? extends VFS> vfsImpl; //本地Session范圍 protected LocalCacheScope localCacheScope = LocalCacheScope.SESSION; //數據庫類型 protected JdbcType jdbcTypeForNull = JdbcType.OTHER; //延遲加載的方法 protected Set<String> lazyLoadTriggerMethods = new HashSet<String>( Arrays.asList(new String[] { 'equals', 'clone', 'hashCode', 'toString' })); //默認執行語句超時 protected Integer defaultStatementTimeout; //默認的執行器 protected ExecutorType defaultExecutorType = ExecutorType.SIMPLE; //數據庫ID protected String databaseId; //mapper注冊表 protected final MapperRegistry mapperRegistry = new MapperRegistry(this); //攔截器鏈 protected final InterceptorChain interceptorChain = new InterceptorChain(); //類型處理器 protected final TypeHandlerRegistry typeHandlerRegistry = new TypeHandlerRegistry(); //類型別名 protected final TypeAliasRegistry typeAliasRegistry = new TypeAliasRegistry(); //語言驅動 protected final LanguageDriverRegistry languageRegistry = new LanguageDriverRegistry(); //mapper_id 和 mapper文件的映射 protected final Map<String, MappedStatement> mappedStatements = new StrictMap<MappedStatement>( 'Mapped Statements collection'); //mapper_id和緩存的映射 protected final Map<String, Cache> caches = new StrictMap<Cache>('Caches collection'); //mapper_id和返回值的映射 protected final Map<String, ResultMap> resultMaps = new StrictMap<ResultMap>('Result Maps collection'); //mapper_id和參數的映射 protected final Map<String, ParameterMap> parameterMaps = new StrictMap<ParameterMap>('Parameter Maps collection'); //資源列表 protected final Set<String> loadedResources = new HashSet<String>(); 未完.......}構建MappedStatement

在Configuration中,有個mappedStatements的屬性,這是個MappedStatement對象Map的集合,其key是這個mapper的namespace+對應節點的id,而value是一個MappedStatement對象。在構建Configuration的時候,會去解析我們的配置文件。解析配置文件的關鍵代碼如下

private void parseConfiguration(XNode root) { try { //issue #117 read properties first propertiesElement(root.evalNode('properties')); Properties settings = settingsAsProperties(root.evalNode('settings')); loadCustomVfs(settings); loadCustomLogImpl(settings); typeAliasesElement(root.evalNode('typeAliases')); pluginElement(root.evalNode('plugins')); objectFactoryElement(root.evalNode('objectFactory')); objectWrapperFactoryElement(root.evalNode('objectWrapperFactory')); reflectorFactoryElement(root.evalNode('reflectorFactory')); settingsElement(settings); // read it after objectFactory and objectWrapperFactory issue #631 environmentsElement(root.evalNode('environments')); databaseIdProviderElement(root.evalNode('databaseIdProvider')); typeHandlerElement(root.evalNode('typeHandlers')); mapperElement(root.evalNode('mappers')); } catch (Exception e) { throw new BuilderException('Error parsing SQL Mapper Configuration. Cause: ' + e, e); }}

上訴代碼段倒數第三行mapperElement(root.evalNode('mappers'));就是解析mappers處就是把我們的mapper文件封裝成MappedStatement對象,然后保存到Configuration的mappedStatements屬性中,其中key是這個mapper的namespace+對應節點的id,而value是一個MappedStatement對象。保存的地方關鍵代碼如下

configuration.addMappedStatement(statement);

addMappedStatement()方法代碼如下

protected final Map<String, MappedStatement> mappedStatements = new StrictMap<MappedStatement>( 'Mapped Statements collection');public void addMappedStatement(MappedStatement ms) {mappedStatements.put(ms.getId(), ms);}

那么這個MappedStatement的又是何許人也?我們可以簡單的把MapperStatement理解為對sql的一個封裝,在MappedStatement中保存著一個SqlSource對象,其中就存有SQL的信息。相關代碼如下

public final class MappedStatement {private SqlSource sqlSource;}

SqlSource 代碼如下

public interface SqlSource { BoundSql getBoundSql(Object parameterObject);}

BoundSql代碼如下

public class BoundSql { private final String sql; private final List<ParameterMapping> parameterMappings;}

關于二級緩存我們在Configuration中看到了一個caches屬性

protected final Map<String, Cache> caches = new StrictMap<>('Caches collection');

這個東西的作用是什么呢?其實是關于Mybatis的二級緩存的。在解析配置文件的過程中,如果用到了二級緩存,便會把這個ID和對象也保存到configuration的caches中,相關代碼如下

public void addCache(Cache cache) { caches.put(cache.getId(), cache);}構建SqlSessionFactory

在Configuration對象構建完畢之后,就該依賴Configuration對象去構建SqlSessionFactory對象了,相關代碼如下

public SqlSessionFactory build(Configuration config) { return new DefaultSqlSessionFactory(config);}

我們暫且把SqlSessionFactory稱為SqlSession工廠吧,SqlSessionFactory中有兩個方法,openSession()和getConfiguration()SqlSessionFactory代碼如下

public interface SqlSessionFactory { SqlSession openSession(); //其余openSession重載方法略… Configuration getConfiguration();}構建SqlSession

openSession()方法會返回一個SqlSession對象,SqlSession又是何許人也?SqlSession可以理解為程序與數據庫打交道的一個工具,通過它,程序可以往數據庫發送SQL執行。SqlSession代碼如下

public interface SqlSession extends Closeable { <T> T selectOne(String statement); <T> T selectOne(String statement, Object parameter); <E> List<E> selectList(String statement); <E> List<E> selectList(String statement, Object parameter); //其余增刪查改方法略…}總結

想必你已經明白了,Mybatis解析xml最主要的目的其實是構建Configuration對象,這個對象中可以說包含著Mybatis的所有配置信息。其中有一個mappedStatements屬性,這是一個Map,其中key是這個mapper的namespace+對應節點的id,而value是一個MappedStatement對象,而MappedStatement中保存著一個SqlSource對象,這個對象中保存著我們要執行的SQL語句。

那么在下一章,我們將一起探究Mybatis是如何執行我們的SQL語句的。

到此這篇關于詳解Mybatis是如何解析配置文件的的文章就介紹到這了,更多相關Mybatis 解析配置文件內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲日韩中文字幕一区| 国产精品av久久久久久麻豆网| 一区二区国产精品| 日本在线一区二区三区| 欧美激情三区| 日韩精品一区二区三区免费观看| 国产手机视频一区二区| 日本午夜精品久久久久| 国产中文在线播放| 日韩亚洲国产欧美| 日韩av不卡一区二区| 精品国产不卡| 在线国产一区二区| 欧美三区不卡| 午夜精品成人av| 综合激情在线| 精品日产乱码久久久久久仙踪林| 亚洲一级二级| 欧美日韩亚洲国产精品| 日韩精品第一区| 中文字幕成人| 精品视频免费| 亚洲一区日韩| 久久精品资源| 国产一区二区精品| 国产精品sss在线观看av| 亚洲一级高清| 国产乱码精品一区二区三区四区| 欧美sm一区| 日本欧美一区| 久久久国产精品一区二区中文| 亚洲视频国产精品| 色综合五月天| 日韩精品欧美精品| 国产超碰精品| 国产精品大片| 亚洲一区二区三区四区电影| 狠狠久久伊人| 日日夜夜免费精品| 日韩精品永久网址| 欧美亚洲色图校园春色| 国产高清久久| 精品资源在线| 亚洲天堂日韩在线| 神马午夜久久| 精品深夜福利视频| 日韩精品免费观看视频| 日韩精品看片| 国产精品va视频| 伊人久久一区| 黄色日韩精品| 国产69精品久久| 欧美日韩精品一区二区三区视频| 午夜国产欧美理论在线播放 | 久久久一二三| 欧美激情久久久久久久久久久| 9国产精品视频| 亚洲黄色免费av| 免费一级欧美片在线观看网站| 中文不卡在线| 亚洲天堂黄色| 91一区二区三区四区| 国产精品白丝一区二区三区| 蜜臀av亚洲一区中文字幕| 久久国产影院| 精品中文在线| 国产麻豆一区二区三区精品视频| 热久久国产精品| 蜜桃成人av| 天堂√中文最新版在线| 国产精品久久久久久久久久久久久久久 | 日韩视频久久| 婷婷综合六月| 在线看片福利| 成人精品动漫一区二区三区| 免费在线日韩av| 欧美一区=区三区| 四虎在线精品| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲专区在线| 免费国产自久久久久三四区久久| 美女福利一区二区三区| 精品一区二区三区中文字幕| 国产毛片久久久| 国产麻豆一区二区三区| 日本午夜精品久久久| 亚洲不卡视频| 亚洲日本国产| 亚洲精品三级| 日本欧美久久久久免费播放网| 日日夜夜免费精品| 亚洲3区在线| 日本午夜免费一区二区| 日韩福利视频导航| 欧美性www| 欧美天堂一区| 国产精品综合| 在线视频精品| 中文日韩在线| 亚洲欧美日本国产| 婷婷综合一区| 日韩高清成人在线| 国产精品毛片久久久| 黄色aa久久| 99久久九九| 在线成人直播| 男女性色大片免费观看一区二区 | 六月婷婷一区| 伊人久久一区| 久久激情综合网| 国产精品资源| 欧美黄色一区二区| 国产a亚洲精品| 香蕉久久精品| 亚洲精品综合| 国产精品高清一区二区| 激情综合五月| 久久激情中文| 99在线观看免费视频精品观看| 日韩中文字幕麻豆| 亚洲免费一区三区| 国产免费播放一区二区| 不卡专区在线| 深夜福利视频一区二区| 91久久在线| 欧美永久精品| 日韩欧美一区二区三区在线视频| 欧美日韩少妇| 国产精品97| 亚洲精品一区二区在线播放∴| 国产精品17p| 不卡福利视频| 亚洲激情久久| 日本高清久久| 日韩高清一级| 福利一区二区免费视频| 成人av二区| 在线看片日韩| 久久97视频| 欧美日韩日本国产亚洲在线| 91嫩草精品| 免费污视频在线一区| 国产精品毛片| 久久国产人妖系列| 91精品一区国产高清在线gif | 影音先锋久久| 日韩欧美2区| 成人在线免费观看网站| 亚洲欧美日韩在线观看a三区| 欧美亚洲tv| 婷婷成人综合| 欧美一区不卡| 欧美一区二区三区激情视频 | 日韩精品午夜| 91精品麻豆| 在线日韩电影| 日韩动漫一区| 精品捆绑调教一区二区三区| 日韩有码av| 日韩精品永久网址| 视频国产精品| 亚洲综合在线电影| 亚洲欧洲美洲国产香蕉| 日韩电影免费在线观看| 日韩欧美2区| 蜜桃tv一区二区三区| 欧美国产另类| 免费观看久久久4p| 日韩成人三级| 欧美日本不卡| 伊人精品在线| 麻豆视频在线看| 日本三级亚洲精品| 五月天久久久| 精品久久久久中文字幕小说| 亚洲区欧美区| 国精品一区二区三区| 国产精品国产三级在线观看| 热久久免费视频| 欧美亚洲国产一区| 国产一区二区三区四区五区传媒 | 99久久亚洲精品蜜臀| 国产精品一区三区在线观看| 99国产精品久久久久久久| 麻豆成人91精品二区三区| 午夜在线一区| 视频福利一区| 国产+成+人+亚洲欧洲在线| 日韩精品高清不卡| 欧美成人国产| 中文在线а√天堂| 国产精品一卡| 日韩区一区二| 午夜在线视频一区二区区别| 久久九九电影| 国产一区国产二区国产三区| 欧美一级二区| 日韩精品亚洲一区二区三区免费| 国产毛片久久| 国产v综合v|