MyBatis學(xué)習(xí):MyBatis中的一級(jí)緩存
緩存的作用是減輕數(shù)據(jù)庫的壓力,提高數(shù)據(jù)庫的性能的。mybatis中提供了一級(jí)緩存和二級(jí)緩存,先來看一下兩個(gè)緩存的示意圖:
從圖中可以看出:
一級(jí)緩存是SqlSession級(jí)別的緩存。在操作數(shù)據(jù)庫時(shí)需要構(gòu)造sqlSession對(duì)象,在對(duì)象中有一個(gè)數(shù)據(jù)結(jié)構(gòu)(HashMap)用于存儲(chǔ)緩存數(shù)據(jù)。不同的sqlSession之間的緩存數(shù)據(jù)區(qū)域(HashMap)是互相不影響的。
二級(jí)緩存是mapper級(jí)別的緩存,多個(gè)SqlSession去操作同一個(gè)Mapper的sql語句,多個(gè)SqlSession可以共用二級(jí)緩存,二級(jí)緩存是跨SqlSession的。
我們來看下一級(jí)緩存的工作原理:
從圖中可以看出:第一次發(fā)起查詢用戶id為1的用戶信息,先去找緩存中是否有id為1的用戶信息,如果沒有,從數(shù)據(jù)庫查詢用戶信息。得到用戶信息,將用戶信息存儲(chǔ)到一級(jí)緩存中。
如果中間sqlSession去執(zhí)行commit操作(執(zhí)行插入、更新、刪除),則會(huì)清空SqlSession中的一級(jí)緩存,這樣做的目的為了讓緩存中存儲(chǔ)的是最新的信息,避免臟讀。
第二次發(fā)起查詢用戶id為1的用戶信息,先去找緩存中是否有id為1的用戶信息,緩存中有,直接從緩存中獲取用戶信息。mybatis的一級(jí)緩存比較簡單,我們不知不覺中就在用了,我寫一個(gè)測試代碼來測一下: