您好,登錄后才能下訂單哦!
本篇文章為大家展示了深入淺析MyBatis中的二級緩存,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
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>
全局開關(guān)
<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語句默認(rèn)都將被緩存,此命名空間下所有insert、update、delete語句將會導(dǎo)致空間下的緩存被清空。
可以針對具體某條語句禁用緩存。
<select id="retObj" resultMap="results" useCache="false" > select id, name, sex from employee </select>
也可針對某條語句觸發(fā)刷新動作(默認(rèn)對應(yīng)所有插入、更新、刪除語句)。
<select id="retObj" resultMap="results" flushCache="true" > select id, name, sex from employee </select>
配置參數(shù)在memcached.properties中設(shè)置,如果缺失則使用缺省設(shè)置。
以下是配置參數(shù):
如果需要記錄cache操作日志,可由如下配置實現(xiàn)
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.LoggingMemcachedCache" /> ... </mapper>
注意事項
緩存在Memcached中的類需要實現(xiàn)Serializable接口,否則會報錯java.io.NotSerializableException。
二級緩存應(yīng)用場景
實現(xiàn)方法如下:
通過設(shè)置刷新間隔時間,由mybatis每隔一段時間自動清空緩存,根據(jù)數(shù)據(jù)變化頻率設(shè)置緩存刷新間隔flushInterval,比如設(shè)置為30分鐘、60分鐘、24小時等,根據(jù)需求而定。
mybatis局限性
mybatis二級緩存對細粒度的數(shù)據(jù)級別的緩存實現(xiàn)不好。
比如如下需求:對商品信息進行緩存,由于商品信息查詢訪問量大,但是要求用戶每次都能查詢最新的商品信息,此時如果使用mybatis的二級緩存就無法實現(xiàn)當(dāng)一個商品變化時只刷新該商品的緩存信息而不刷新其它商品的信息,因為mybaits的二級緩存區(qū)域以mapper為單位劃分,當(dāng)一個商品信息變化會將所有商品信息的緩存數(shù)據(jù)全部清空。解決此類問題需要在業(yè)務(wù)層根據(jù)需求對數(shù)據(jù)有針對性緩存。
上述內(nèi)容就是深入淺析MyBatis中的二級緩存,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。