MyBatis關于二級緩存問題
MyBatis提供一級緩存和二級緩存,其中一級緩存是sqlSession級別的緩存,不同的sqlSession之間的緩存互不影響。二級緩存是Mapper級別的緩存,多個sqlSession操作同一個Mapper,其二級緩存是可以共享的。
MyBatis有多種二級緩存方案可供選擇。其中對Memcached的支持較為成熟,現(xiàn)以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>
也可針對某條語句觸發(fā)刷新動作(默認對應所有插入、更新、刪除語句)。
<select id="retObj" resultMap="results" flushCache="true" > select id, name, sex from employee </select>
配置參數(shù)在memcached.properties中設置,如果缺失則使用缺省設置。
以下是配置參數(shù):
如果需要記錄cache操作日志,可由如下配置實現(xiàn)
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.LoggingMemcachedCache" /> ... </mapper>
注意事項
緩存在Memcached中的類需要實現(xiàn)Serializable接口,否則會報錯java.io.NotSerializableException。
二級緩存應用場景
- 對查詢頻率高,變化頻率低的數(shù)據(jù)建議使用二級緩存。
- 對于訪問多的查詢請求且用戶對查詢結果實時性要求不高,此時可采用mybatis二級緩存技術降低數(shù)據(jù)庫訪問量,提高訪問速度,業(yè)務場景比如:耗時較高的統(tǒng)計分析sql、電話賬單查詢sql等。
實現(xiàn)方法如下:
通過設置刷新間隔時間,由mybatis每隔一段時間自動清空緩存,根據(jù)數(shù)據(jù)變化頻率設置緩存刷新間隔flushInterval,比如設置為30分鐘、60分鐘、24小時等,根據(jù)需求而定。
mybatis局限性
mybatis二級緩存對細粒度的數(shù)據(jù)級別的緩存實現(xiàn)不好。
比如如下需求:對商品信息進行緩存,由于商品信息查詢訪問量大,但是要求用戶每次都能查詢最新的商品信息,此時如果使用mybatis的二級緩存就無法實現(xiàn)當一個商品變化時只刷新該商品的緩存信息而不刷新其它商品的信息,因為mybaits的二級緩存區(qū)域以mapper為單位劃分,當一個商品信息變化會將所有商品信息的緩存數(shù)據(jù)全部清空。解決此類問題需要在業(yè)務層根據(jù)需求對數(shù)據(jù)有針對性緩存。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
MyBatis-Plus+達夢數(shù)據(jù)庫實現(xiàn)高效數(shù)據(jù)持久化的示例
這篇文章主要介紹了MyBatis-Plus和達夢數(shù)據(jù)庫實現(xiàn)高效數(shù)據(jù)持久化,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-08-08java中使用Files.readLines()處理文本中行數(shù)據(jù)方式
這篇文章主要介紹了java中使用Files.readLines()處理文本中行數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12SpringBoot整合Graylog做日志收集實現(xiàn)過程
這篇文章主要為大家介紹了SpringBoot整合Graylog做日志收集實現(xiàn)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12