1.SqlSessionFactoryBuilder SqlSessionFactoryBuilder是以工具類的方式來使用:需要創(chuàng)建sqlSessionFactory時(shí)就new一個 SqlSessionFactoryBuilder
2.sqlSessionFactory 正常開發(fā)時(shí),以單例方式管理sqlSessionFactory,整個系統(tǒng)運(yùn)行過程中sqlSessionFactory只有一個實(shí)例,將來和SPRing整合后由Spring以單例方式管理sqlSessionFactory
3.SqlSession SqlSession是一個面向用戶(程序員)的接口,程序員調(diào)用 SqlSession接口的方法進(jìn)行操作數(shù)據(jù)庫。那么我們會思考:SqlSession能否以單例方式使用???由于 SqlSession是線程不安全的,所以 SqlSession最佳應(yīng)用范圍在方法體內(nèi)。也就是說在方法體內(nèi)定義局部變量 SqlSession的對象來使用。
我們先來看看MyBatis原始開發(fā)dao的開發(fā)方式,發(fā)現(xiàn)原始開發(fā)的問題,然后再來看看MyBatis使用mapper動態(tài)代理開發(fā)dao的方式(也是MyBatis目前使用的開發(fā)dao的方式)。
程序員需要編寫dao接口: 和dao接口的實(shí)現(xiàn)類:
然后就能在測試類中使用。測試類代碼如下:
我們來看看這種方式開發(fā)有什么問題?
下面我們看看mapper動態(tài)代理的方式。
這種方式下程序員只需要寫dao接口,dao接口實(shí)現(xiàn)對象由mybatis自動生成代理對象。因?yàn)楸旧韉ao在三層架構(gòu)中就是一個通用的接口。
要想讓mybatis自動創(chuàng)建dao接口實(shí)現(xiàn)類的代理對象,必須要遵循一些規(guī)則:
1.mapper.xml中 namespace指定為mapper接口的全限定名。此步驟的目的:將mapper.xml和mapper.java關(guān)聯(lián)。2.mapper.xml中statement的id就是mapper.java中的方法名。3.mapper.xml中statement的parameterType和mapper.java中方法輸入?yún)?shù)一致。4.mapper.xml中statement的resultType和mapper.java中方法的返回值類型一致。采用這種方式后,我們便可將第一篇文章中提到的User.xml改為UserMapper.xml。文件目錄如下:
其中有些類我們會在后面用到。
mapper映射文件的命名方式建議表名加Mapper.xml,namespace指定為mapper接口的全限定名。
mybatis提出了mapper接口,相當(dāng)于dao接口,mapper接口的命名方式建議為表名加Mapper.
public interface UserMapper{};在UserMapper.java中添加如下兩個方法:
對于UserMapper.xml,不管查詢記錄是單條還是多條,在statement(即UserMapper.xml)中的resultType都定義一致,都是單條記錄映射的pojo類型。
而對于UserMapper.java接口方法中的返回值,如果返回的是單個對象,返回值類型是pojo,生成的代理對象內(nèi)部會自動通過selectOne獲取記錄,如果返回值類型是多條對象,生成的代理對象內(nèi)部會自動通過selectList獲取記錄。
測試代碼如下:
使用Mapper代理方式進(jìn)行開發(fā),使程序員只需要關(guān)注UserMapper.java接口中的方法,它的實(shí)現(xiàn)類由Mapper自動為我們生成,帶來了很大的方便。但這種方式也有它的弊端。
新聞熱點(diǎn)
疑難解答