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

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

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

瀏覽:186日期: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久久,三上悠亚国产精品一区二区三区
欧美一级网站| 国产精品4hu.www| 免费污视频在线一区| 伊人久久在线| 国产二区精品| 综合激情婷婷| 国产精品多人| 成人日韩在线观看| 国产在线视频欧美一区| 色老板在线视频一区二区| 精品一区在线| 日本不卡在线视频| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 欧美精品观看| 97精品国产99久久久久久免费| 国产欧美一区二区三区国产幕精品 | 欧美有码在线| 久草免费在线视频| 国产一区导航| 国产精品亚洲综合在线观看| 日韩电影免费在线观看| 久久亚洲电影| 国产麻豆精品久久| av高清一区| 日欧美一区二区| 成人亚洲一区二区| 中文无码久久精品| 成人午夜亚洲| 在线精品一区| а√天堂8资源中文在线| 亚洲黄页一区| 国产伦精品一区二区三区千人斩| 日本а中文在线天堂| 婷婷综合一区| 肉色欧美久久久久久久免费看| 亚洲综合福利| 久久精品日韩欧美| 精品捆绑调教一区二区三区| 在线日韩成人| 欧洲精品一区二区三区| 亚洲精品少妇| 欧美日韩一区二区综合| 国产无遮挡裸体免费久久| 亚洲午夜视频| 久久久国产精品网站| 在线精品观看| 自由日本语亚洲人高潮| 国产aⅴ精品一区二区四区| 综合视频一区| 国产精品88久久久久久| 国产专区精品| 国产亚洲电影| 午夜在线视频观看日韩17c| 国产精品原创| 欧美精品97| 日韩国产一区二| 欧美专区在线| 不卡中文一二三区| 国产精品毛片久久| 国产美女撒尿一区二区| 999国产精品999久久久久久| 麻豆久久久久久久| 911亚洲精品| 亚洲香蕉视频| 秋霞国产精品| 精品国产午夜肉伦伦影院 | 国产成年精品| 国产精品一国产精品| 亚洲色图国产| 久久亚洲欧洲| 欧美日韩国产免费观看| 国产一二在线播放| 欧美国产专区| 国产精品一区二区三区www| 亚洲欧美网站| 人人精品亚洲| 日本久久综合| 老牛国内精品亚洲成av人片| 青草国产精品| 在线视频精品| 久久精品国产亚洲夜色av网站| 亚洲97av| 91久久久久| 九九久久电影| 日韩久久精品网| 国产 日韩 欧美 综合 一区| 国产精品一区二区99| 日韩福利在线观看| 涩涩涩久久久成人精品| 亚洲有吗中文字幕| 三级在线观看一区二区| 午夜日本精品| 午夜久久免费观看| 久久久久久美女精品| 手机在线电影一区| 老鸭窝一区二区久久精品| 久久高清免费观看| 黄色亚洲免费| 激情久久中文字幕| 激情综合网站| 久久大逼视频| 亚洲精品麻豆| 日本欧美韩国一区三区| 日韩精品亚洲专区| 日韩精品久久理论片| 国产亚洲人成a在线v网站| 国产亚洲观看| 精品国产a一区二区三区v免费| 久久永久免费| 激情国产在线| 激情综合自拍| 亚洲精品888| 美国欧美日韩国产在线播放| 人人爽香蕉精品| 在线免费观看亚洲| 亚洲精品激情| 日韩三级视频| 欧美国产专区| 日韩欧美少妇| 在线一区视频| 日韩精选在线| 精品国产精品国产偷麻豆| 亚洲精品成人图区| aⅴ色国产欧美| 四虎在线精品| 欧美交a欧美精品喷水| 久久精品资源| 美女网站视频一区| 视频一区国产视频| 国产精品一区二区免费福利视频| 久久久久久久久成人| 激情欧美一区二区三区| 亚洲天堂免费| 麻豆一区在线| 天堂√8在线中文| 亚洲专区欧美专区| 国产亚洲一卡2卡3卡4卡新区| 精品五月天堂| 午夜国产精品视频免费体验区| 亚洲精品在线a| 精品国产不卡一区二区| 日韩精品首页| 亚洲精品在线a| 国产69精品久久| 国产精品视区| 国产精品www994| 精精国产xxxx视频在线野外| 婷婷综合激情| 国产精品一区免费在线| 99精品美女| 欧美日韩一区二区三区四区在线观看 | 国产亚洲高清一区| 久久精品国内一区二区三区| 亚洲五月婷婷| 青青在线精品| 亚洲一级特黄| 久久99国产精品视频| 国产毛片一区| 国产精品久久久久久久久久10秀| 久久大逼视频| 国产精品毛片久久| 日韩精品免费观看视频| 久久国产毛片| 国产精品白丝av嫩草影院| 黄色日韩在线| 国产日韩中文在线中文字幕| 成人在线视频免费看| 一级成人国产| 都市激情国产精品| 蜜桃视频在线观看一区| 色在线中文字幕| 久久国产精品色av免费看| 欧美中文一区二区| 久久一区精品| 涩涩涩久久久成人精品| 久久蜜桃av| 麻豆精品在线观看| 亚洲精品伊人| 青青久久av| 欧美亚洲tv| 国产亚洲在线观看| 欧美激情麻豆| 亚州国产精品| 99成人在线视频| 激情综合婷婷| 日韩av字幕| 美女精品网站| 久久69成人| 91成人在线网站| 蜜桃久久精品一区二区| 久久精品不卡| 亚洲精品福利电影| 精品午夜久久| 免费一级欧美在线观看视频| 欧美伊人久久| 亚洲欧美专区| 伊人精品一区| 伊人久久在线| 加勒比视频一区| 免费在线日韩av|