MyBatis包含一個非常強大的查詢快取特性,它可以非常方便地配置和自訂。預設是沒有開啟快取的,要開啟二級緩存,你需要在你的SQL映射檔中新增一行:
<cache/>
字面上看就是這樣。這個簡單語句的效果如下:
1.映射語句檔案中的所有select語句將會被快取。
2.映射語句檔案中的所有insert,update和delete語句會刷新快取。
3.快取會使用Least Recently Used(LRU,最近最少使用的)演算法來收回。
4.根據時間表(例如 no Flush Interval,沒有刷新間隔),快取不會以任何時間順序來刷新。
5.快取會儲存清單集合或物件(無論查詢方法回傳什麼)的1024個參考。
6.快取會被視為是read/write(可讀/可寫)的緩存,意味著物件檢索不是共享的,而且可以安全地被呼叫者修改,而不干擾其他呼叫者或執行緒所做的潛在修改。
所有的這些屬性都可以透過快取元素的屬性來修改。比如:
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
這個更高級的配置創建了一個FIFO緩存,並每隔60秒刷新,存儲結果對像或列表的512個引用,而且返回的對像被認為是唯讀的,因此在不同線程中的調用者之間修改它們會導致衝突。
可用的收回策略(eviction)有:
LRU – 最近最少使用的:移除最長時間不被使用的物件。
FIFO – 先進先出:按物件進入快取的順序來移除它們。
SOFT – 軟引用:移除基於垃圾回收器狀態和軟引用規則的物件。
WEAK – 弱引用:更積極移除基於垃圾收集器狀態和弱引用規則的物件。
預設的是 LRU。
flushInterval(刷新間隔)可以設定為任意的正整數,而且它們代表一個合理的毫秒形式的時間段。預設情況是不設置,也就是沒有刷新間隔,快取僅調用語句時刷新。
size(引用數目)可以被設定為任意正整數,要記住你快取的物件數目和你運行環境的可用記憶體資源數目。預設值1024。
readOnly(唯讀)屬性可以被設定為 true 或 false。只讀的快取會給所有呼叫者傳回快取物件的相同實例。因此這些物件不能被修改。這提供了很重要的效能優勢。可讀寫的快取會傳回快取物件的拷貝(透過序列化)。這會慢一些,但是安全,因此預設是false。
使用自訂快取
除了這些自訂快取的方式,你也可以透過實作你自己的快取或為其他第三方快取方案建立適配器來完全覆寫快取行為。
<cache type=”com.domain.something.MyCustomCache”/>
這個範例展示如何使用一個自訂的快取實作。 type 屬性指定的類別必須實作org.mybatis.cache.Cache 介面。這個介面是 MyBatis 框架中許多複雜的介面之一,但是簡單給定它做什麼就行。
public interface Cache { String getId(); int getSize(); void putObject(Object key, Object value); Object getObject(Object key); boolean hasKey(Object key); Object removeObject(Object key); void clear(); ReadWriteLock getReadWriteLock(); }
參考快取
也許將來的某個時候,你會想在命名空間中共享相同的快取配置和實例。在這樣的情況下你可以使用 cache-ref 元素來引用另外一個快取。
<cache-ref namespace=”com.someone.application.data.SomeMapper”/>
更多Java的MyBatis框架中XML映射快取的使用教學相關文章請關注PHP中文網!