mybatis中的緩存機(jī)制
mybatis的緩存機(jī)制
一、mybatis和同是持久層的hibernate一樣
都存在著緩存機(jī)制,今天來說一下mybatis的緩存機(jī)制。
查詢緩存來緩存數(shù)據(jù),從而達(dá)到提高查詢性能的要求,以提高我們項(xiàng)目的效率!!
二、mybatis的緩存機(jī)制有兩級(jí)
- (1)一級(jí)緩存:一級(jí)緩存mybatsi已近為我們自動(dòng)開啟,不用我們手動(dòng)操作,而且我們是關(guān)閉不了的??!但是我們可以手動(dòng)清除緩存。(SqlSession級(jí)別)
- (2)二級(jí)緩存:二級(jí)緩存需要我們手動(dòng)開啟。(全局級(jí)別)
三、一級(jí)緩存
存在要求 | 同一個(gè)SqlSession中,在沒有收到改變該數(shù)據(jù)的請求之前! |
代碼以及效果:
一 | 并不是同一個(gè)Sqlsession對(duì)象 |
二 | 在查詢的過程中,兩次的查詢條件不同(其實(shí)這個(gè)不用我說大家也知道) |
三 | 在兩次之間進(jìn)行了增,刪,改,操作 |
四 | 在兩次之間自己進(jìn)行了手動(dòng)清空緩存 |
緩存失效的效果如下:
四:二級(jí)緩存
二級(jí)緩存的作用:通過度一級(jí)緩存的了解。推擠緩存是基于同一個(gè)SqlSesion類的實(shí)例對(duì)象的。但是,有些時(shí)候在wenb工廠中將會(huì)執(zhí)行查詢操作的方法分裝在某個(gè)Service方法中,當(dāng)查詢完一次后,Service方法結(jié)束,此時(shí)SqlSession類的實(shí)例對(duì)象就會(huì)關(guān)閉,一級(jí)緩存就會(huì)被清空。此時(shí)若再次調(diào)用用Service方法查詢同一個(gè)信息,此時(shí)異界緩存就是空的,從而無法從緩存中獲取信息??!
因此,我們可以使用二級(jí)緩存,二級(jí)緩存存在與Mapper實(shí)例中,當(dāng)多個(gè)SqlSession類的實(shí)例對(duì)象加載相同的mapper文件,并執(zhí)行其中國的SQL配置時(shí),他們就共享一個(gè)Mapper緩存。當(dāng)某個(gè)SqlSession類的實(shí)例對(duì)象執(zhí)行了增,刪,改,等改變數(shù)據(jù)的操作時(shí),Mapper實(shí)例都會(huì)清空其二級(jí)緩存!
開啟二級(jí)緩存:
開啟二級(jí)緩存需要兩個(gè)步驟,第一步在mybatis的全局配置文件中配置Setting屬性,設(shè)置名為cacheEnabled的屬性值為true即可
<settings> <!-- (1):開啟二級(jí)緩存,這個(gè)全局的配置二級(jí)緩存 默認(rèn)是開啟的,但是還是需要寫上,防止版本的更新 --> <setting name="cacheEnabled" value="true"/> </settings>
第二步:在具體需要二級(jí)緩存的mapeer映射文件中開啟二級(jí)緩存,值需要在相應(yīng)的映射文件中添加一個(gè)cache標(biāo)簽即可
(2):在相應(yīng)的映射文件中開啟二級(jí)緩存 <!-- 開啟二級(jí)緩存 --> ??? ?<cache></cache>?? ?
效果以及其代碼:
MyBatis緩存機(jī)制是什么?
mybatis一級(jí)緩存是 SqlSession 級(jí)別的緩存,默認(rèn)支持一級(jí)緩存,不需要在配置文件去配置。
mybaits的二級(jí)緩存是 mapper 范圍級(jí)別,除了在 SqlMapConfig.xml 設(shè)置二級(jí)緩存的總開關(guān)<settingname=‘cacheEnabled’ value=‘true’/>
還要在具體的 mapper.xml 中開啟二級(jí)緩存:<mappernamespace=‘cn.hpu.mybatis.mapper.UserMapper’>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JAVA環(huán)境搭建之MyEclipse10+jdk1.8+tomcat8環(huán)境搭建詳解
本文詳細(xì)講解了MyEclipse10+jdk1.8+tomcat8的JAVA環(huán)境搭建方法,希望能幫助到大家2018-10-10使用Java開發(fā)實(shí)現(xiàn)OAuth安全認(rèn)證的應(yīng)用
這篇文章主要介紹了使用Java開發(fā)實(shí)現(xiàn)OAuth安全認(rèn)證的應(yīng)用的方法,OAuth安全認(rèn)證經(jīng)常出現(xiàn)于社交網(wǎng)絡(luò)API應(yīng)用的相關(guān)開發(fā)中,需要的朋友可以參考下2015-11-11Java微信支付之公眾號(hào)支付、掃碼支付實(shí)例
微信支付已經(jīng)成為生活中必不可少的付款方式,本篇文章主要介紹了Java微信支付之公眾號(hào)支付、掃碼支付,有需要的小伙伴可以了解一下。2016-11-11Java Spring中Quartz調(diào)度器詳解及實(shí)例
這篇文章主要介紹了Java Spring中Quartz調(diào)度器詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-02-02springboot2.1.7整合thymeleaf代碼實(shí)例
這篇文章主要介紹了springboot2.1.7整合thymeleaf代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12springMVC前臺(tái)傳數(shù)組類型,后臺(tái)用list類型接收實(shí)例代碼
這篇文章主要介紹了springMVC前臺(tái)傳數(shù)組類型,后臺(tái)用list類型接收實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12使用java生成json時(shí)產(chǎn)生棧溢出錯(cuò)誤問題及解決方案
這篇文章主要介紹了使用java生成json時(shí)產(chǎn)生棧溢出錯(cuò)誤問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06elasticsearch源碼分析index?action實(shí)現(xiàn)方式
這篇文章主要為大家介紹了elasticsearch源碼分析index?action實(shí)現(xiàn)方式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04