MyBatis提供一級緩存和二級緩存,其中一級緩存是sqlSession級別的緩存,不同的sqlSession之間的緩存互不影響。二級緩存是Mapper級別的緩存,多個sqlSession操作同一個Mapper,其二級緩存是可以共享的。
MyBatis有多種二級緩存方案可供選擇。其中對Memcached的支持較為成熟,現以Memcached為例介紹與spring項目的集成。
使用配置
配置pom.xml,添加依賴。
1
2
3
4
5
6
7
8
9
|
< dependencies > ... < dependency > < groupId >org.mybatis.caches</ groupId > < artifactId >mybatis-memcached</ artifactId > < version >1.0.0</ version > </ dependency > ... </ dependencies > |
全局開關
1
2
3
|
< settings > < setting name = "cacheEnabled" value = "true" /> </ settings > |
配置需要緩存的mapper.xml
二級緩存是Mapper級別的,可以針對具體的mapper.xml開啟二級緩存。
1
2
3
|
< mapper namespace = "org.acme.FooMapper" > < cache type = "org.mybatis.caches.memcached.MemcachedCache" /> </ mapper > |
開啟后,則mapper中所有的select語句默認都將被緩存,此命名空間下所有insert、update、delete語句將會導致空間下的緩存被清空。
可以針對具體某條語句禁用緩存。
1
2
3
|
< select id = "retObj" resultMap = "results" useCache = "false" > select id, name, sex from employee </ select > |
也可針對某條語句觸發刷新動作(默認對應所有插入、更新、刪除語句)。
1
2
3
|
< select id = "retObj" resultMap = "results" flushCache = "true" > select id, name, sex from employee </ select > |
配置參數在memcached.properties中設置,如果缺失則使用缺省設置。
以下是配置參數:
如果需要記錄cache操作日志,可由如下配置實現
1
2
3
4
|
< 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為單位劃分,當一個商品信息變化會將所有商品信息的緩存數據全部清空。解決此類問題需要在業務層根據需求對數據有針對性緩存。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://www.jianshu.com/p/5156a855f893