MyBatis關(guān)于二級(jí)緩存問題
MyBatis提供一級(jí)緩存和二級(jí)緩存,其中一級(jí)緩存是sqlSession級(jí)別的緩存,不同的sqlSession之間的緩存互不影響。二級(jí)緩存是Mapper級(jí)別的緩存,多個(gè)sqlSession操作同一個(gè)Mapper,其二級(jí)緩存是可以共享的。
MyBatis有多種二級(jí)緩存方案可供選擇。其中對(duì)Memcached的支持較為成熟,現(xiàn)以Memcached為例介紹與spring項(xiàng)目的集成。
使用配置
配置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
二級(jí)緩存是Mapper級(jí)別的,可以針對(duì)具體的mapper.xml開啟二級(jí)緩存。
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.MemcachedCache" /> </mapper>
開啟后,則mapper中所有的select語句默認(rèn)都將被緩存,此命名空間下所有insert、update、delete語句將會(huì)導(dǎo)致空間下的緩存被清空。
可以針對(duì)具體某條語句禁用緩存。
<select id="retObj" resultMap="results" useCache="false" > select id, name, sex from employee </select>
也可針對(duì)某條語句觸發(fā)刷新動(dòng)作(默認(rèn)對(duì)應(yīng)所有插入、更新、刪除語句)。
<select id="retObj" resultMap="results" flushCache="true" > select id, name, sex from employee </select>
配置參數(shù)在memcached.properties中設(shè)置,如果缺失則使用缺省設(shè)置。
以下是配置參數(shù):
如果需要記錄cache操作日志,可由如下配置實(shí)現(xiàn)
<mapper namespace="org.acme.FooMapper"> <cache type="org.mybatis.caches.memcached.LoggingMemcachedCache" /> ... </mapper>
注意事項(xiàng)
緩存在Memcached中的類需要實(shí)現(xiàn)Serializable接口,否則會(huì)報(bào)錯(cuò)java.io.NotSerializableException。
二級(jí)緩存應(yīng)用場(chǎng)景
- 對(duì)查詢頻率高,變化頻率低的數(shù)據(jù)建議使用二級(jí)緩存。
- 對(duì)于訪問多的查詢請(qǐng)求且用戶對(duì)查詢結(jié)果實(shí)時(shí)性要求不高,此時(shí)可采用mybatis二級(jí)緩存技術(shù)降低數(shù)據(jù)庫訪問量,提高訪問速度,業(yè)務(wù)場(chǎng)景比如:耗時(shí)較高的統(tǒng)計(jì)分析sql、電話賬單查詢sql等。
實(shí)現(xiàn)方法如下:
通過設(shè)置刷新間隔時(shí)間,由mybatis每隔一段時(shí)間自動(dòng)清空緩存,根據(jù)數(shù)據(jù)變化頻率設(shè)置緩存刷新間隔flushInterval,比如設(shè)置為30分鐘、60分鐘、24小時(shí)等,根據(jù)需求而定。
mybatis局限性
mybatis二級(jí)緩存對(duì)細(xì)粒度的數(shù)據(jù)級(jí)別的緩存實(shí)現(xiàn)不好。
比如如下需求:對(duì)商品信息進(jìn)行緩存,由于商品信息查詢?cè)L問量大,但是要求用戶每次都能查詢最新的商品信息,此時(shí)如果使用mybatis的二級(jí)緩存就無法實(shí)現(xiàn)當(dāng)一個(gè)商品變化時(shí)只刷新該商品的緩存信息而不刷新其它商品的信息,因?yàn)閙ybaits的二級(jí)緩存區(qū)域以mapper為單位劃分,當(dāng)一個(gè)商品信息變化會(huì)將所有商品信息的緩存數(shù)據(jù)全部清空。解決此類問題需要在業(yè)務(wù)層根據(jù)需求對(duì)數(shù)據(jù)有針對(duì)性緩存。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java利用FTPClient實(shí)現(xiàn)文件上傳和下載的實(shí)踐指南
本文介紹如何使用Java中的FTPClient庫來執(zhí)行文件的上傳和下載操作,首先,講解了FTPClient的基本用法,包括連接FTP服務(wù)器和登錄驗(yàn)證,然后,詳細(xì)說明了如何使用 storeFile() 和 retrieveFile() 方法分別實(shí)現(xiàn)文件上傳和下載,需要的朋友可以參考下2025-05-05Java實(shí)現(xiàn)驗(yàn)證文件名有效性的方法詳解
在本文中,我們將討論使用?Java?驗(yàn)證一個(gè)給定的字符串是否具有操作系統(tǒng)的有效文件名的不同方法,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-09-09Spring核心IoC容器的依賴注入接口和層級(jí)包命名規(guī)范
這篇文章主要介紹了Spring核心IoC容器的依賴注入接口和層級(jí)包命名規(guī)范,IOC又名控制反轉(zhuǎn),把對(duì)象創(chuàng)建和對(duì)象之間的調(diào)用過程,交給Spring進(jìn)行管理,目的是為了降低耦合度,需要的朋友可以參考下2023-05-05SpringBoot項(xiàng)目整合MybatisPlus并使用SQLite作為數(shù)據(jù)庫的過程
SQLite是一個(gè)緊湊的庫,啟用所有功能后,庫大小可以小于 750KiB, 具體取決于目標(biāo)平臺(tái)和編譯器優(yōu)化設(shè)置, 內(nèi)存使用量和速度之間需要權(quán)衡,這篇文章主要介紹了SpringBoot項(xiàng)目整合MybatisPlus并使用SQLite作為數(shù)據(jù)庫,需要的朋友可以參考下2024-07-07