日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

mybatis一級緩存和二級緩存理解與區別

作者:xsx_only 更新時間: 2022-07-22 編程語言

一級緩存

作用域:一級緩存是基于sqlsession默認開啟的,在操作數據庫時需要構造SqlSession對象,在對象中有一個HashMap用于存儲緩存數據。不同的SqlSession之間的緩存數據區域是互相不影響的。

一級緩存作用是sqlsession范圍的,在同一個sqlsession中執行兩次相同的sql時,第一次得到的數據會緩存放在內存中,第二次不再去數據庫獲取,而是直接在緩存中獲取,提高效率。

何時失效:在中間如果執行了增刪改并提交到數據庫,mybatis是會把sqlsession中的一級緩存清空的,這樣是為了數據的準確性,避免臟讀現象;當關閉一個sqlsession時,一級緩存也隨之消失。

二級緩存

作用域:二級緩存是基于mapper的namespace作用域,但多個sqlsession操作同一個namespace下的sql時,并且傳入的參數也相同,執行相同的sql語句,第一次執行完畢后,自動將sql提交會將數據緩存,這就是二級緩存。

底層數據存儲:二級緩存是在一級緩存使用HashMap的基礎上增加了一層Map進行數據存儲。相比一級緩存SqlSession,二級緩存的范圍更大,多個Sqlsession可以共用二級緩存,二級緩存它是可以跨越多個sqlsession的。

如何開啟:開啟二級緩存,在MyBatis的全局配置settings中有一個參數cacheEnabled,這個參數是二級緩存的全局開關

在保證二級緩存全局配置開啟情況下,給mapper.xml開啟二級緩存添加<cache/>元素即可。

默認的二級緩存會有如下效果:

  • 映射語句文件中的所有SELECT語句將會被緩存。
  • 映射語句文件中所有INSERT、UPDATE、DELETE語句會被刷新緩存。
  • 緩存會使用Least Recently Used 算法來收回。
  • 根據時間表(如 no Flush Interval,沒有刷新間隔),緩存不會以任何時間順序來刷新。
  • 緩存會存儲集合或對象(無論查詢方法返回什么類型的值)的1024個引用。
  • 緩存會被視為read/write(可讀/可寫)的,意味著對象檢索不是共享的,而且可以安全地被調用者修改,而不擾其他調用者或線程所做的潛在修改。

原文鏈接:https://blog.csdn.net/xiaoxu9522/article/details/125917813

欄目分類
最近更新