核心組件
- SqlSessionFactoryBuilder(構(gòu)造器):它會(huì)根據(jù)配置信息或者代碼來生成 SqlSessionFactory(工廠接口)。
- SqlSessionFactory:依靠工廠來生成 SqlSession(會(huì)話)猬仁。
- SqlSession:一個(gè)既可以發(fā)送 SQL 去執(zhí)行并返回結(jié)果芝雪,也可以獲取 Mapper 的接口晃财。
- SQL Mapper:它是 MyBatis 新設(shè)計(jì)的組件, 它是由一個(gè) Java 接口和 XML 文件(或注解)構(gòu)成的狼牺,需要給出對(duì)應(yīng)的 SQL 和映射規(guī)則禁添。它負(fù)責(zé)發(fā)送 SQL 語句,并返回結(jié)果寨昙。
用一張圖表達(dá)它們之間的關(guān)聯(lián):
生命周期
SqlSessionFactoryBuilder
SqlSessionFactoryBuilder 是利用 XML 或者 Java 編碼獲得資源來構(gòu)建 SqlSessionFactory 的讥巡,通過它可以構(gòu)建多個(gè) SessionFactory。它的作用就是一個(gè)構(gòu)建器舔哪,一旦我們構(gòu)建了 SqlSessionFactory欢顷,它的作用就已經(jīng)完結(jié)了,失去了存在的意義捉蚤。所以它的生命周期只存在于方法的內(nèi)部抬驴。
SqlSessionFactory
SqlSessionFactory 的作用是創(chuàng)建 SqlSession炼七,而 SqlSession 就是一個(gè)會(huì)話,相當(dāng)于 JDBC 中的 Connection 對(duì)象布持。每次應(yīng)用程序訪問數(shù)據(jù)庫豌拙,我們都需要 SqlSessionFactory 創(chuàng)建 SqlSession,所以 SqlSessionFactory 應(yīng)該在 MyBatis 應(yīng)用的整個(gè)生命周期中题暖。而如果我們多次創(chuàng)建同一個(gè)數(shù)據(jù)庫的 SqlSessionFactory按傅,則每次創(chuàng)建 SqlSessionFactory 會(huì)打開更多的數(shù)據(jù)庫連接資源,那么連接資源就很快會(huì)被耗盡胧卤。因此 SqlSessionFactory 的責(zé)任是唯一的唯绍,它的責(zé)任就是創(chuàng)建 SqlSession,所以應(yīng)該采用單利模式枝誊。正確的做法是使得每一個(gè)數(shù)據(jù)庫只對(duì)應(yīng)一個(gè) SqlSessionFactory况芒,管理好數(shù)據(jù)庫資源的分配,避免過多的 Connection 被消耗侧啼。
SqlSession
SqlSession 是一個(gè)會(huì)話牛柒,相當(dāng)于 JDBC 的一個(gè) Connection 對(duì)象堪簿,它的生命周期應(yīng)該是在請(qǐng)求數(shù)據(jù)庫處理事務(wù)的過程中痊乾。它是一個(gè)線程不安全的對(duì)象,在涉及多線程的時(shí)候我們需要特別小心椭更,操作數(shù)據(jù)庫需要注意其隔離級(jí)別哪审,數(shù)據(jù)庫鎖等高級(jí)特效。此外虑瀑,每次創(chuàng)建的 SqlSession 都必須及時(shí)關(guān)閉它湿滓,它的長(zhǎng)期存在會(huì)使數(shù)據(jù)庫連接池的活動(dòng)資源減少,對(duì)系統(tǒng)性能的影響太大舌狗。我們往往通過 finally 語句保證我們正確的關(guān)閉 SQLSession叽奥。它存活于一個(gè)應(yīng)用的請(qǐng)求和操作,可以執(zhí)行多條 SQL痛侍,保證事務(wù)的一致性朝氓。
Mapper
Mapper 是一個(gè)接口,而沒有具體的實(shí)現(xiàn)類主届,它的作用是發(fā)送 SQL赵哲,然后返回我們需要的結(jié)果,或者執(zhí)行 SQL 從而修改數(shù)據(jù)庫的數(shù)據(jù)君丁,因此它應(yīng)該在一個(gè) SqlSession 事務(wù)方法之內(nèi)枫夺,是一個(gè)方法級(jí)別的東西。
用一張圖描述 MyBatis 組件的生命周期: