在Mybatis深入學習的一周中,總感覺跟著師傅的視屏講解什麼都能懂,但實際自己操作的時候才發現自己一臉懵逼,不知道從何入手。但還好自己做了點筆記。在此記錄一下自己淺度學習Mybatis遇到幾個小問題。 1.個人感覺學習Mybatis過程中最好使用log4j 日誌文件,這樣在你自己測試代碼的時候,能 ...
在Mybatis深入學習的一周中,總感覺跟著師傅的視屏講解什麼都能懂,但實際自己操作的時候才發現自己一臉懵逼,不知道從何入手。但還好自己做了點筆記。在此記錄一下自己淺度學習Mybatis遇到幾個小問題。
1.個人感覺學習Mybatis過程中最好使用log4j 日誌文件,這樣在你自己測試代碼的時候,能更好的看到Mybatis的運行過程。不使用的話,測試代碼的時候如果代碼正確他就只會輸入結果,有時候這個結果你是知道的,相比較之下使用log4j你能看到一些過程,這樣在學習中能更好的理解。
作為技術小白的我,也就只會用用log4j。首先是導入jar包,log4j 和slf4j的版本一定要對應,否則會報異常。其次是log4j的配置文件,代碼如上,必須放置src目錄下,然後就可以使用了。
這兩個包是必須的,一個是mybatis的jar包,一個是連輸mysql數據用的jar包
2.就是在配置Constructor 構造器的時候,大家在對應類的構造方式的後儘量使用Interger類似的對象數據類型,因為我在寫構造器的時候用int類型返回資料庫的id列他會報異常。原因是數據不匹配,至於具體的問題,師傅說是源於java反射機制,這裡就不多說了。
3.Mapper映射代理對象,一般來說Mybatis核心配置文件中引入Mapper映射文件有三種方式:1:resource引入映射文件位置 2.class 引入代理對象類3.package引入代理對象所在的包(批量代理)
這裡必須註意的是,class 和 package 引入代理對象時,必須把映射文件和介面類放在同一文件下,同時mapper映射文件中的語句id 必須對應介面的方法名稱。否則代理對象不成功。
然後通過session對象調用getMapper就可以實現對象代理了。
4.一對多和多對多關係理解。 我在學習這一章節的時候,起初是通過sql語句和sql表來理解和思考處理這些關係。其實不然,處理多對多關係的時候,首先先分析類與類的關係或者說表與表的關係 這是必須的,其次在表對應的類中建立連接
這裡P_oder對應Oder是一對一的關係,Product和P_oder是一對多的關係,這裡分析好了,mapper里的語句處理就好解決了
這裡是P_oder的mapper里實現三表聯查,首先找到一對一聯查 ,也就是從資料庫找到數據返回給P_oder對象類里的Oder對象,ResultMap里首先放的是P_oder的基本類型,其次Association就是處理P_oder和Oder的關係,比如這裡是根據p_oder里的p_id 對應Oder里的id,一對多的關係處理也是一樣的原理,只不過 collection 里返回的就是一個集合了,這裡也對應了一對多的關係。
5.在配置Mybatis核心配置的Settings 配置時,要導入兩個jar包。
初學Mybatis的我在這裡就掉坑裡了,這裡cglib的版本據我搜到的資料,應該是要小於asm版本的,我試過相同版本,調試報異常。這裡和log4j 和slf4j不一樣,log4j 和slf4j是需要相同版本。
6.Mybatis 二級緩存。 這裡最繞的就是:當你啟用二緩存,又有insert/update/delect數據處理,又關閉了insert/update/delect 刷新緩存時 。
如果你的數據處理語句在session.close() (向二級緩存刷入數據)的後面,那麼二級緩存中是沒有數據的。雖然我們關閉了二級緩存的數據刷新,也就是當執行數據處理語句時,二級緩存不會被清除,但是這裡會清除一級緩存中的數據,所以把session.close() 一級緩存刷入二級緩存放在數據處理語句前 就可以實現二級緩存中有數據,且不被清除。
<!--這裡就是我入坑時遇到的一些小問題,希望對大家有一定的幫助。歡迎大家留言,一起討論,一起進步。有不對的地方,望大佬指教,也請大家多多包涵!-->