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
用來描述Mapper中的SQL配置信息唇撬,是對(duì)Mapper XML配置文件中<select|insert|update|delete>等標(biāo)簽或者@Select等注解配置信息的封裝SqlSession
Mybatis 為使用者提供的API它匕,表示和數(shù)據(jù)庫交互時(shí)的會(huì)話對(duì)象,用于完成數(shù)據(jù)庫增刪改查功能局荚。SqlSession 是 Executor組件的外觀超凳,目的是對(duì)外提供易于理解和使用的數(shù)據(jù)庫操作接口Executor
是Mybatis 的執(zhí)行器愈污,Mybatis中對(duì)數(shù)據(jù)庫所有的增刪改查操作都是由它完成的StatementHandler
封裝了JDBC StateMent對(duì)象的操作耀态,比如StateMent對(duì)象設(shè)置參數(shù),調(diào)用Statement接口提供的方法與數(shù)據(jù)庫交互等等ParameterHandler
當(dāng)Mybatis框架使用的Statement類型是CallableStatement 和 PreparedStatement時(shí)暂雹,ParameterHandler用于為Statement對(duì)象參數(shù)占位符設(shè)置值ResultSetHandler
封裝了對(duì)JDBC中的ResultSet對(duì)象操作首装,當(dāng)執(zhí)行SQL類型為Select語句時(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é)果