1. 程式人生 > >MyBatis的一級緩存和二級緩存簡介筆記

MyBatis的一級緩存和二級緩存簡介筆記

獲取數據 完全 轉載 app 開啟 namespace 結束 gpo oca

關於mybatis中一級緩存和二級緩存的簡單介紹

mybatis的一級緩存:
  MyBatis會在表示會話的SqlSession對象中建立一個簡單的緩存,將每次查詢到的結果結果緩存起來,
當下次查詢的時候,如果判斷先前有個完全一樣的查詢,會直接從緩存中直接將結果取出,返回給用戶,
不需要再進行一次數據庫查詢了。

  MyBatis會在一次會話的表示----一個SqlSession對象中創建一個本地緩存(local cache),
對於每一次查詢,都會嘗試根據查詢的條件去本地緩存中查找是否在緩存中,如果在緩存中,
就直接從緩存中取出,然後返回給用戶;否則,從數據庫讀取數據,將查詢結果存入緩存並返回給用戶。

  一級緩存是SqlSession級別的緩存。在操作數據庫時需要構造 sqlSession對象,在對象中有一個(內存區域)數據結構(HashMap)用於存儲緩存數據。不同的sqlSession之間的緩存數據區域(HashMap)是互相不影響的。

  一級緩存的作用域是同一個SqlSession,在同一個sqlSession中兩次執行相同的sql語句,第一次執行完畢會將數據庫中查詢的數據寫到緩存(內存),第二次會從緩存中獲取數據將不再從數據庫查詢,從而提高查詢效率。當一個sqlSession結束後該sqlSession中的一級緩存也就不存在了。Mybatis默認開啟一級緩存。

  二級緩存是mapper級別的緩存

,多個SqlSession去操作同一個Mapper的sql語句,多個SqlSession去操作數據庫得到數據會存在二級緩存區域,多個SqlSession可以共用二級緩存,二級緩存是跨SqlSession的。

  二級緩存是多個SqlSession共享的,其作用域是mapper的同一個namespace,不同的sqlSession兩次執行相同namespace下的sql語句且向sql中傳遞參數也相同即最終執行相同的sql語句,第一次執行完畢會將數據庫中查詢的數據寫到緩存(內存),第二次會從緩存中獲取數據將不再從數據庫查詢,從而提高查詢效率。Mybatis默認沒有開啟二級緩存需要在setting全局參數中配置開啟二級緩存。

如果緩存中有數據就不用從數據庫中獲取,大大提高系統性能。

作者:little飛 出處:http://www.cnblogs.com/little-fly/ 歡迎轉載 也請保留這段聲明 謝謝!

MyBatis的一級緩存和二級緩存簡介筆記