色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

mybatis中的一級(jí)緩存深入剖析

瀏覽:128日期:2023-10-21 10:57:07

mybatis中提供有一級(jí)緩存 和 二級(jí)緩存,這里記錄一下一級(jí)緩存

一級(jí)緩存(mybatis中默認(rèn)開啟)

SqlSession級(jí)別的緩存,操作數(shù)據(jù)庫(kù)時(shí)需要構(gòu)造SQLSession對(duì)象, 在對(duì)象中有一個(gè)數(shù)據(jù)結(jié)構(gòu)(HashMap)用于存儲(chǔ)緩存數(shù)據(jù),不同的SQLSession對(duì)象之間的緩存數(shù)據(jù)是不共享的,即獨(dú)立的

根據(jù)第一點(diǎn),簡(jiǎn)單一點(diǎn)講就是一級(jí)緩存是屬于對(duì)象的(個(gè)人記法)

從別處搞來一個(gè)圖,便于我們理解:

mybatis中的一級(jí)緩存深入剖析

下面用spring整合mybatis來測(cè)試一下mybatis的一級(jí)緩存:

1、下面是service層實(shí)現(xiàn), 可以看到,我兩次查詢了同一個(gè)數(shù)據(jù),理論上由于mybatis中默認(rèn)開啟一級(jí)緩存, 那么第二次肯定時(shí)要從緩存中獲取,而不是創(chuàng)建SqlSession對(duì)象重新從數(shù)據(jù)庫(kù)獲取

@Autowiredprivate LsjmUserMapper lsjmUserMapper; @Overridepublic LsjmUser getUser() { // 第一次查詢 LsjmUser user = lsjmUserMapper.getUserByName('300'); System.out.println(user.toString()); // 第二次查詢 LsjmUser user1 = lsjmUserMapper.getUserByName('300'); System.out.println(user1.toString()); return user;}

前臺(tái)頁面觸發(fā)這個(gè)service后,控制臺(tái)打?。?/p>

從日志信息可以很明顯的看到,代碼中的兩次查詢構(gòu)建了兩個(gè)SqlSession對(duì)象,也就是說第二次查詢并沒有從前一次的SqlSession緩存中獲取,而是自己新建一個(gè)SQLSession對(duì)象,重新查詢,,看似,mybatis的一級(jí)緩存失效了?

mybatis中的一級(jí)緩存深入剖析

2、spring 中 結(jié)合 mybatis中,默認(rèn)情況下,數(shù)據(jù)庫(kù)處于自動(dòng)提交模式,每一條sql語句處于一個(gè)單獨(dú)的事務(wù)中,語句執(zhí)行完畢時(shí),如果執(zhí)行成功則隱式提交事務(wù)。而mybatis的一級(jí)緩存在這種情況下是無效的,想要一級(jí)緩存起作用,則要開啟事務(wù):

開啟事務(wù): spring使用ThreadLocal獲取當(dāng)前資源綁定同一個(gè)SQLSession

未開啟事務(wù):每次查詢,spring關(guān)閉舊的SslSession,創(chuàng)建一個(gè)新的Sqlsession對(duì)象,一級(jí)緩存補(bǔ)氣作用

下面Service層中的代碼同樣對(duì)同一個(gè)數(shù)據(jù)查詢了兩次,這次開啟了事務(wù)管理

@Autowiredprivate LsjmUserMapper lsjmUserMapper; @Override@Transactional // 開啟事務(wù)控制,當(dāng)前,spring配置文件中得先配置好public LsjmUser getUser() { // 第一次查詢 LsjmUser user = lsjmUserMapper.getUserByName('300'); System.out.println(user.toString()); // 第二次查詢 LsjmUser user1 = lsjmUserMapper.getUserByName('300'); System.out.println(user1.toString()); return user;}

前臺(tái)頁面觸發(fā)Service后:控制臺(tái)打印日志:

可以看出來第一次查詢時(shí),構(gòu)造了一個(gè)SqlSession對(duì)象,從數(shù)據(jù)庫(kù)查詢數(shù)據(jù),然后將查詢的結(jié)果存儲(chǔ)到一級(jí)緩存SqlSession中,第二次查詢時(shí),直接Fetched SqlSession,而不是再重新建一個(gè),此時(shí)就是從緩存中直接取數(shù)據(jù)了

mybatis中的一級(jí)緩存深入剖析

開啟事務(wù)后取如何取到同一個(gè)SqlSession,源碼解析可以參考這里:spring結(jié)合mybatis時(shí)一級(jí)緩存失效問題

有一點(diǎn)需要注意:

如果對(duì)某個(gè)SqlSession執(zhí)行了commit,則會(huì)清空這個(gè)SqlSession中的一級(jí)緩存,目的是為了防止臟讀,在上面的例子中,如果第一次查詢后,做了一次更新操作,然后sqlSession.commit()了,此時(shí)會(huì)清空整個(gè)SqlSession的一級(jí)緩存,那么第二次查詢時(shí)就得重新的從數(shù)據(jù)中查詢了。

以上這篇mybatis中的一級(jí)緩存深入剖析就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

相關(guān)文章:
主站蜘蛛池模板: 中文字幕播放 | 亚洲伦理天堂 | 99精品国产免费久久国语 | 欧美午夜精品久久久久免费视 | 亚洲成a人片在线看 | 天干夜天天夜天干天ww | 国产精品videossex另类 | 成人免费观看视频久爱网 | 视频一区色眯眯视频在线 | 怡红院免费va男人的天堂 | 国产精品久久毛片蜜月 | 一级特黄爽大片刺激 | 美国毛片毛片全部免费 | 成年女人免费观看视频 | 美国毛片一级 | 狠狠色丁香久久婷婷综 | 久久免费黄色 | 亚洲精品亚洲人成在线麻豆 | 男人天堂怡红院 | 亚洲欧美日韩久久精品第一区 | 亚洲国产毛片aaaaa无费看 | 鲁一鲁色一色 | 三级国产在线 | 欧美日韩顶级毛片www免费看 | 亚洲mm8成为人影院 亚洲m男在线中文字幕 | 免费成人毛片 | 国产大陆亚洲精品国产 | 一级做a爰片久久毛片16 | 精品国产一区二区三区不卡蜜臂 | 呦视频在线一区二区三区 | 国产国语在线播放视频 | 在线观看国产一区二区三区 | 久久精品视| 91亚洲国产 | 国产精品久久久久久福利漫画 | 国产精品久久久久影视不卡 | 综合欧美视频一区二区三区 | 一区二区三区中文国产亚洲 | 国产原创系列在线 | 日韩成人在线观看视频 | 欧美日韩视频一区二区三区 |