緩存的作用是減輕數(shù)據(jù)庫的壓力,提高數(shù)據(jù)庫的性能的。mybatis中提供了一級緩存和二級緩存,先來看一下兩個緩存的示意圖:
從圖中可以看出:
1.一級緩存是SqlSession級別的緩存淤井。在操作數(shù)據(jù)庫時需要構(gòu)造sqlSession對象,在對象中有一個數(shù)據(jù)結(jié)構(gòu)(HashMap)用于存儲緩存數(shù)據(jù)出爹。不同的sqlSession之間的緩存數(shù)據(jù)區(qū)域(HashMap)是互相不影響的庄吼。
2.二級緩存是mapper級別的緩存,多個SqlSession去操作同一個Mapper的sql語句严就,多個SqlSession可以共用二級緩存总寻,二級緩存是跨SqlSession的。
一級緩存的工作原理:
從圖中可以看出:第一次發(fā)起查詢用戶id為1的用戶信息梢为,先去找緩存中是否有id為1的用戶信息渐行,如果沒有轰坊,從數(shù)據(jù)庫查詢用戶信息。得到用戶信息祟印,將用戶信息存儲到一級緩存中肴沫。
如果中間sqlSession去執(zhí)行commit操作(執(zhí)行插入、更新蕴忆、刪除)颤芬,則會清空SqlSession中的一級緩存,這樣做的目的為了讓緩存中存儲的是最新的信息套鹅,避免臟讀站蝠。
第二次發(fā)起查詢用戶id為1的用戶信息,先去找緩存中是否有id為1的用戶信息卓鹿,緩存中有菱魔,直接從緩存中獲取用戶信息。
mybatis的一級緩存比較簡單吟孙,我們不知不覺中就在用了澜倦,為了完整性,我寫一個測試代碼來測一下:
@Test
public void testCache1() throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();//創(chuàng)建代理對象
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
//下邊查詢使用一個SqlSession
//第一次發(fā)起請求杰妓,查詢id為1的用戶
User user1 = userMapper.findUserById(1);
System.out.println(user1);
// 如果sqlSession去執(zhí)行commit操作(執(zhí)行插入藻治、更新、刪除)稚失,清空SqlSession中的一級緩存栋艳,這樣做的目的為了讓緩存中存儲的是最新的信息,避免臟讀句各。
//更新user1的信息
user1.setUsername("測試用戶22");
userMapper.updateUser(user1);
//執(zhí)行commit操作去清空緩存
sqlSession.commit();
//第二次發(fā)起請求,查詢id為1的用戶
User user2 = userMapper.findUserById(1);
System.out.println(user2);
sqlSession.close();
}