這篇文章主要介紹了MyBatis關於二級緩存問題,二級緩存是Mapper層級的緩存,多個sqlSession操作同一個Mapper,其二級緩存是可以共享的。
MyBatis提供一級緩存和二級緩存,其中一級緩存是sqlSession級別的緩存,不同的sqlSession之間的緩存互不影響。二級緩存是Mapper層級的緩存,多個sqlSession操作同一個Mapper,其二級緩存是可以共享的。
MyBatis有多種二級快取方案可供選擇。其中對Memcached的支援較為成熟,現以Memcached為例介紹與spring專案的整合。
使用設定
配置pom.xml,新增依賴。
<dependencies> ... <dependency> <groupId>org.mybatis.caches</groupId> <artifactId>mybatis-memcached</artifactId> <version>1.0.0</version> </dependency> ... </dependencies>
全域開關
<settings> <setting name="cacheEnabled" value="true"/> </settings>
配置需要快取的mapper.xml
二級快取是Mapper層級的,可以針對具體的mapper.xml開啟二級快取。
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.MemcachedCache" /> </mapper>
開啟後,則mapper中所有的select語句預設都會被緩存,此命名空間下所有insert、update、delete語句將會導致空間下的快取被清空。
可以針對特定某條語句停用快取。
<select id="retObj" resultMap="results" useCache="false" > select id, name, sex from employee </select>
也可針對某條語句觸發刷新動作(預設對應所有插入、更新、刪除語句)。
<select id="retObj" resultMap="results" flushCache="true" > select id, name, sex from employee </select>
配置參數在memcached.properties中設置,如果缺失則使用預設設定。
以下是設定參數:
如果需要記錄cache操作日誌,可由下列設定實作
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.LoggingMemcachedCache" /> ... </mapper>
快取在Memcached中的類別需要實作Serializable接口,否則會報錯java.io.NotSerializableException。
二級快取應用程式場景
對查詢頻率高,變化頻率低的資料建議使用二級快取。
對於存取多的查詢請求且使用者對查詢結果即時性要求不高,此時可採用mybatis二級快取技術降低資料庫存取量,提高存取速度,業務場景例如:耗時較高的統計分析sql、電話帳單查詢sql等。
實作方法如下:
透過設定刷新間隔時間,由mybatis每隔一段時間自動清空緩存,根據資料變化頻率設定快取刷新間隔flushInterval,例如設定為30分鐘、60分鐘、24小時等,依需求而定。
mybatis限制
mybatis二級快取對細粒度的資料層級的快取實作不好。
例如如下需求:對商品資訊進行緩存,由於商品資訊查詢訪問量大,但是要求用戶每次都能查詢最新的商品信息,此時如果使用mybatis的二級緩存就無法實現當一個商品變化時只刷新該商品的緩存信息而不刷新其它商品的信息,因為mybaits的二級緩存區域以mapper為單位劃分,當一個商品信息變化會將所有商品資訊的快取資料全部清空。解決此類問題需要在業務層根據需求對資料有針對性快取。
以上是詳解MyBatis關於二級快取問題的程式碼實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!