天天看點

Mybatis_緩沖機制

文章目錄

  • ​​1.一級緩存​​
  • ​​1.1 一級緩存初體驗​​
  • ​​1.2 一級緩存失效​​
  • ​​2.二級緩存​​
  • ​​2.1 開啟二級緩存​​
  • ​​2.2 二級緩存的屬性​​
  • ​​2.3 相關配置屬性​​
  • ​​3.緩存原理圖​​

1級緩存是SqlSession級别的,

2級緩存是namespace級别的:和接口的全類名一緻,不管用任何一個SqlSession執行了目前某一個映射檔案中的查詢語句,這個資料都會被緩存,下一次不管用任何的SqlSesiion,都會從緩存中去取

1.一級緩存

本地緩存

與資料庫同一次會話期間查詢到的資料會放在本地緩存中

以後如果需要擷取相同的資料,直接從緩存中拿

一級緩存是自動開啟的。下面的4種方法是使得一級緩存失效的

  • 1.sqlSession不同
  • 2.sqlSession相同,查詢條件不同
  • 3.sqlSession相同,查詢期間執行了增删操作
  • 4.手動清除了一級緩存

1.1 一級緩存初體驗

@Test
    public void test1()throws Exception{
        SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
        SqlSession openSession = sqlSessionFactory.openSession();
        EmployMapper mapper = openSession.getMapper(EmployMapper.class);
        Employee id = mapper.getId(2);
        System.out.println(id);
        Employee id1 = mapper.getId(2);
        System.out.println(id1);
        openSession.close();
    }
      
Mybatis_緩沖機制

由于有一級緩存的緣故,是以不用再調用sqlSession

1.2 一級緩存失效

1.sqlSession不同

@Test
    public void test1()throws Exception{
        SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
        SqlSession openSession = sqlSessionFactory.openSession();
        EmployMapper mapper = openSession.getMapper(EmployMapper.class);
        Employee id = mapper.getId(2);
        System.out.println(id);
        SqlSession openSession1 = sqlSessionFactory.openSession();
        EmployMapper mapper1 = openSession1.getMapper(EmployMapper.class);
        Employee id1 = mapper1.getId(2);
        System.out.println(id1);
        openSession.close();
    }
      
Mybatis_緩沖機制

由于SqlSession的不同

使得沒有緩存

2.sqlSession相同,查詢條件不同

Mybatis_緩沖機制
Mybatis_緩沖機制

3.sqlSession相同,查詢期間執行了增删操作

Mybatis_緩沖機制
Mybatis_緩沖機制

4.手動清除了一級緩存

Mybatis_緩沖機制

執行了openSession.clearCache()方法

Mybatis_緩沖機制

2.二級緩存

全局緩存

是基于namespace級别的緩存,一個namespace對一個二級緩存

  • 1.查詢一條資料,放在一級緩存
  • 2.如果會話關閉,一級到二級,新的會話資訊,會參照二級緩存
  • 3.不同的namespace會放在不同的map中,不同的二級緩存中
    Mybatis_緩沖機制

2.1 開啟二級緩存

開啟二級緩存

Mybatis_緩沖機制

test.java

@Test
    public void test2()throws Exception{
        SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
        SqlSession openSession = sqlSessionFactory.openSession();
        SqlSession openSession1 = sqlSessionFactory.openSession();
        EmployMapper mapper = openSession.getMapper(EmployMapper.class);
        EmployMapper mapper1 = openSession1.getMapper(EmployMapper.class);
        Employee id = mapper.getId(3);
        System.out.println(id);
        openSession.close();
        Employee id1 = mapper1.getId(3);
        System.out.println(id1);
        openSession1.close();
    }
      

注意要關閉再擷取第二個,不然不會開啟二級緩存,因為隻有會話關閉的時候一級緩存才會轉為二級緩存

Mybatis_緩沖機制

2.2 二級緩存的屬性

Mybatis_緩沖機制

cacheEnabled=“true”

開啟二級緩存

cacheEnabled=“false”

關閉二級緩存,但是一級緩存沒有關閉

Mybatis_緩沖機制

useCache=“false”

則二級緩存不可以使用,但是一級緩存還可以使用

Mybatis_緩沖機制

flushCache="true"的話一級和二級緩存都會清除

預設為false

為什麼在添加增删改的話緩存會失效。因為增删改的flushCache=true,而insert的flushCache=false。

是以如何使得二級緩存失效?

1.在查詢中執行一次增删改即可,flushCache=true

2.useCache=false

一般隻需要記住第一條即可。

2.3 相關配置屬性

3.緩存原理圖