亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mybatis中的緩存機制

 更新時間:2023年06月05日 08:43:43   作者:靈澤~  
這篇文章主要介紹了mybatis中的緩存機制用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis的緩存機制

一、mybatis和同是持久層的hibernate一樣

都存在著緩存機制,今天來說一下mybatis的緩存機制。

查詢緩存來緩存數(shù)據(jù),從而達到提高查詢性能的要求,以提高我們項目的效率!!

二、mybatis的緩存機制有兩級

  • (1)一級緩存:一級緩存mybatsi已近為我們自動開啟,不用我們手動操作,而且我們是關(guān)閉不了的??!但是我們可以手動清除緩存。(SqlSession級別)
  • (2)二級緩存:二級緩存需要我們手動開啟。(全局級別)

三、一級緩存

緩存存在的條件
存在要求同一個SqlSession中,在沒有收到改變該數(shù)據(jù)的請求之前!

代碼以及效果:

緩存失效的條件
并不是同一個Sqlsession對象
在查詢的過程中,兩次的查詢條件不同(其實這個不用我說大家也知道)
在兩次之間進行了增,刪,改,操作
在兩次之間自己進行了手動清空緩存

緩存失效的效果如下:

四:二級緩存

二級緩存的作用:通過度一級緩存的了解。推擠緩存是基于同一個SqlSesion類的實例對象的。但是,有些時候在wenb工廠中將會執(zhí)行查詢操作的方法分裝在某個Service方法中,當(dāng)查詢完一次后,Service方法結(jié)束,此時SqlSession類的實例對象就會關(guān)閉,一級緩存就會被清空。此時若再次調(diào)用用Service方法查詢同一個信息,此時異界緩存就是空的,從而無法從緩存中獲取信息?。?/p>

因此,我們可以使用二級緩存,二級緩存存在與Mapper實例中,當(dāng)多個SqlSession類的實例對象加載相同的mapper文件,并執(zhí)行其中國的SQL配置時,他們就共享一個Mapper緩存。當(dāng)某個SqlSession類的實例對象執(zhí)行了增,刪,改,等改變數(shù)據(jù)的操作時,Mapper實例都會清空其二級緩存!

開啟二級緩存:

開啟二級緩存需要兩個步驟,第一步在mybatis的全局配置文件中配置Setting屬性,設(shè)置名為cacheEnabled的屬性值為true即可

<settings>
		<!-- 
			(1):開啟二級緩存,這個全局的配置二級緩存
			       默認是開啟的,但是還是需要寫上,防止版本的更新 
		-->
		<setting name="cacheEnabled" value="true"/>
</settings>

第二步:在具體需要二級緩存的mapeer映射文件中開啟二級緩存,值需要在相應(yīng)的映射文件中添加一個cache標(biāo)簽即可

(2):在相應(yīng)的映射文件中開啟二級緩存
<!-- 開啟二級緩存 -->
??? ?<cache></cache>?? ?

效果以及其代碼:

MyBatis緩存機制是什么?

mybatis一級緩存是 SqlSession 級別的緩存,默認支持一級緩存,不需要在配置文件去配置。

mybaits的二級緩存是 mapper 范圍級別,除了在 SqlMapConfig.xml 設(shè)置二級緩存的總開關(guān)<settingname=‘cacheEnabled’ value=‘true’/>

還要在具體的 mapper.xml 中開啟二級緩存:<mappernamespace=‘cn.hpu.mybatis.mapper.UserMapper’>

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論