Mybatis快取機制

2022-06-22 15:39:10 字數 2346 閱讀 8374

mybatis有一級快取和二級快取。

首先看一下什麼是一級快取,一級快取是指sqlsession。一級快取的作用域是乙個sqlsession。mybatis預設開啟一級快取。

在同乙個sqlsession中,執行相同的查詢sql,第一次會去查詢資料庫,並寫到快取中;第二次直接從快取中獲取。當執行sql查詢前後發生增刪改操作時,則sqlsession的快取清空。

具體可以看這段**:

開啟兩個sqlsession

從列印日誌可以看出,前面兩個說明sqlsession1的會話快取生效了,第三個對sqlsession2會話執行了更新操作,這時候資料庫發生資料變化,sqlsession2被清空。可是在執行第四個查詢是,是查詢的sqlsession1會話,由於sqlsession1沒有被清空,所以還是查詢的快取的資料,是資料更新之前的,查詢的是髒資料,一級快取sqlsession是不共享的。證明了一級快取只是在資料庫會話內部共享的。

上面說到二級快取可以共享多個sqlsession。可以解決不同sqlsession回話中查詢到髒資料的問題了。

首先,mybatis預設是開啟一級快取的,即同乙個sqlsession每次查詢都會去快取中查詢,沒有資料的話,再去資料庫獲取資料。但是,整合到springboot中後,一級快取就會被關閉。為什麼會出現這種原因呢,可以看下這篇文章:

好了,現在來建立專案,可以根據前一篇文章來建立專案,在這基礎上修改

加上這個標籤,二級快取就會開啟,他的預設屬性如下

這個更高階的配置建立了乙個 fifo 快取,並每隔 60 秒重新整理,存數結果物件或列表的 512 個引用,而且返回的物件被認為是唯讀的,因此在不同執行緒中的呼叫者之間修改它們會 導致衝突。

​ 可用的收回策略有:

預設的是 lru。

flushinterval(重新整理間隔)可以被設定為任意的正整數,而且它們代表乙個合理的毫秒 形式的時間段。預設情況是不設定,也就是沒有重新整理間隔,快取僅僅呼叫語句時重新整理。

​ size(引用數目)可以被設定為任意正整數,要記住你快取的物件數目和你執行環境的 可用記憶體資源數目。預設值是 1024。

​ readonly(唯讀)屬性可以被設定為 true 或 false。唯讀的快取會給所有呼叫者返回緩 存物件的相同例項。因此這些物件不能被修改。這提供了很重要的效能優勢。可讀寫的快取 會返回快取物件的拷貝(通過序列化) 。這會慢一些,但是安全,因此預設是 false。

編寫controller介面

通過postman傳送介面請求進行測試:

通過日誌可以看到,第一次傳送1介面請求,對資料庫進行了查詢

可以看到,第二次和第三次查詢沒有查詢資料庫的sql列印,而是去資料庫獲取資料

此時傳送3介面,進行更新操作,在傳送1介面,查詢改使用者的資料

可以看到,當執行資料庫更新操作後,再進行查詢,此時快取已經清空,需要從資料庫中重新查詢獲取。

這就演示了springboot整合mybatis的快取機制測試。

1、快取的物件必須實現序列化。因為二級快取的資料不一定都是儲存到記憶體中,它的儲存介質多種多樣,所以需要給快取的物件執行序列化,才可以確保獲取無誤。

2、mybatis的二級快取相比於一級快取來說,實現了sqlsession之間的快取資料的共享,做到namespace級別,粒度更細

3、在分布式環境下,由於預設的mybatis cache實現都是基於本地的,分布式環境下必然會出現讀取到髒資料,需要使用集中式快取將mybatis的cache介面實現,有一定的開發成本,直接使用redis、memcached等分布式快取可能成本更低,安全性也更高。

不過建議mybatis的快取特性再生產環境下進行關閉,單純作為乙個orm框架使用可能更加合適。

下篇文章計畫寫springboot整合mybatis,使用redis實現快取基本配置。

mybatis快取機制

mybatis和hibernate一樣,也提供了一二級快取。若存在一二級快取,則資料不會去資料庫互動,而是去記憶體中獲取。一級快取是sqlsession級別的快取。在運算元據庫時需要構造sqlsession物件,在物件中有乙個資料結構 一般來說是hashmap 來儲存快取資料。不同的sqlsessi...

MyBatis 快取機制

mybatis 提供了查詢快取來獲取資料,以提高查詢的效能。mybatis 的快取分為一級快取和二級快取。1 一級快取一級快取是 sqlsession 級別的快取,是基於 hashmap 的本地快取。不同的 sqlsession 之間的快取資料區域互不影響。當同乙個 sqlsession 執行兩次相...

Mybatis 快取機制

查詢快取主要是為了提高查詢訪問速度,即當使用者執行一次查詢後,會將該資料結果放到快取中,當下次再執行此查詢時就不會訪問資料庫了而是直接從快取中獲取該資料。如果在快取中找到了資料那叫做命中。同一sqlsession 多次查詢同一sql時會使用快取 test public void testlocalc...