Mybatis 的執(zhí)行流程及核心組件如圖所示

組件作用:
Configuration
用于描述Mybatis主配置文件信息,當(dāng)Mybatis應(yīng)用啟動(dòng)時(shí)候,將Mapper配置信息、類型別名、TypeHandler等注冊(cè)到Configuration組建中,其他組件需要以上信息時(shí)直接從Configuration中獲取,除此之外,Configuration組件還作為Executor、StatementHandler、ResultSetHandler、ParameterHandler組件的工廠類,用于創(chuàng)建這些組件的實(shí)例。Configuration類中提供了這些組件的工廠方法MappedStatement
用來(lái)描述Mapper中的SQL配置信息,是對(duì)Mapper XML配置文件中<select|insert|update|delete>等標(biāo)簽或者@Select等注解配置信息的封裝SqlSession
Mybatis 為使用者提供的API,表示和數(shù)據(jù)庫(kù)交互時(shí)的會(huì)話對(duì)象,用于完成數(shù)據(jù)庫(kù)增刪改查功能。SqlSession 是 Executor組件的外觀,目的是對(duì)外提供易于理解和使用的數(shù)據(jù)庫(kù)操作接口Executor
是Mybatis 的執(zhí)行器,Mybatis中對(duì)數(shù)據(jù)庫(kù)所有的增刪改查操作都是由它完成的StatementHandler
封裝了JDBC StateMent對(duì)象的操作,比如StateMent對(duì)象設(shè)置參數(shù),調(diào)用Statement接口提供的方法與數(shù)據(jù)庫(kù)交互等等ParameterHandler
當(dāng)Mybatis框架使用的Statement類型是CallableStatement 和 PreparedStatement時(shí),ParameterHandler用于為Statement對(duì)象參數(shù)占位符設(shè)置值ResultSetHandler
封裝了對(duì)JDBC中的ResultSet對(duì)象操作,當(dāng)執(zhí)行SQL類型為Select語(yǔ)句時(shí),ResultSetHandler用于將查詢結(jié)果轉(zhuǎn)換成JAVA對(duì)象TypeHandler
是Mybatis中的類型處理器,用于處理Java類型與JDBC類型之間的映射。它的作用主要體現(xiàn)在能夠根據(jù)Java類型調(diào)用PreparedStatement或CallableStatement對(duì)象應(yīng)對(duì)的SetXXX()方法為Statement對(duì)象設(shè)置值,而且能夠根據(jù)Java類型調(diào)用ResultSet對(duì)象調(diào)用ResultSet對(duì)象對(duì)應(yīng)的getXXX()獲取SQL執(zhí)行結(jié)果