文章出處

緩存的作用是減輕數據庫的壓力,提高數據庫的性能的。mybatis中提供了一級緩存和二級緩存,先來看一下兩個緩存的示意圖: 
緩存示意圖 
  從圖中可以看出:

 

  1. 一級緩存是SqlSession級別的緩存。在操作數據庫時需要構造sqlSession對象,在對象中有一個數據結構(HashMap)用于存儲緩存數據。不同的sqlSession之間的緩存數據區域(HashMap)是互相不影響的。
  2. 二級緩存是mapper級別的緩存,多個SqlSession去操作同一個Mapper的sql語句,多個SqlSession可以共用二級緩存,二級緩存是跨SqlSession的。

 這篇博文主要總結一下mybatis中的一級緩存,看一下一級緩存的工作原理: 
一級緩存工作原理 
  從圖中可以看出:第一次發起查詢用戶id為1的用戶信息,先去找緩存中是否有id為1的用戶信息,如果沒有,從數據庫查詢用戶信息。得到用戶信息,將用戶信息存儲到一級緩存中。 
  如果中間sqlSession去執行commit操作(執行插入、更新、刪除),則會清空SqlSession中的一級緩存,這樣做的目的為了讓緩存中存儲的是最新的信息,避免臟讀。 
  第二次發起查詢用戶id為1的用戶信息,先去找緩存中是否有id為1的用戶信息,緩存中有,直接從緩存中獲取用戶信息。 
  mybatis的一級緩存比較簡單,我們不知不覺中就在用了,為了完整性,我寫一個測試代碼來測一下:

 

@Test
public void testCache1() throws Exception {
    SqlSession sqlSession = sqlSessionFactory.openSession();//創建代理對象
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

    //下邊查詢使用一個SqlSession
    //第一次發起請求,查詢id為1的用戶
    User user1 = userMapper.findUserById(1);
    System.out.println(user1);

//      如果sqlSession去執行commit操作(執行插入、更新、刪除),清空SqlSession中的一級緩存,這樣做的目的為了讓緩存中存儲的是最新的信息,避免臟讀。

    //更新user1的信息
    user1.setUsername("測試用戶22");
    userMapper.updateUser(user1);
    //執行commit操作去清空緩存
    sqlSession.commit();

    //第二次發起請求,查詢id為1的用戶
    User user2 = userMapper.findUserById(1);
    System.out.println(user2);

    sqlSession.close();

}

 

 

一級緩存很簡單,就不再贅述了,下一篇博文來總結一下mybatis的二級緩存。 

 

 緩存的作用是減輕數據庫的壓力,提高數據庫的性能的。mybatis中提供了一級緩存和二級緩存,先來看一下兩個緩存的示意圖: 
緩存示意圖 
  從圖中可以看出:

  1. 一級緩存是SqlSession級別的緩存。在操作數據庫時需要構造sqlSession對象,在對象中有一個數據結構(HashMap)用于存儲緩存數據。不同的sqlSession之間的緩存數據區域(HashMap)是互相不影響的。
  2. 二級緩存是mapper級別的緩存,多個SqlSession去操作同一個Mapper的sql語句,多個SqlSession可以共用二級緩存,二級緩存是跨SqlSession的。

文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()