更新時(shí)間:2021-06-21 11:34:16 來源:動(dòng)力節(jié)點(diǎn) 瀏覽1641次
區(qū)別
1.一級(jí)緩存 Mybatis的一級(jí)緩存是指SQLSession,一級(jí)緩存的作用域是SQlSession, Mabits默認(rèn)開啟一級(jí)緩存。 在同一個(gè)SqlSession中,執(zhí)行相同的SQL查詢時(shí);第一次會(huì)去查詢數(shù)據(jù)庫,并寫在緩存中,第二次會(huì)直接從緩存中取。 當(dāng)執(zhí)行SQL時(shí)候兩次查詢中間發(fā)生了增刪改的操作,則SQLSession的緩存會(huì)被清空。 每次查詢會(huì)先去緩存中找,如果找不到,再去數(shù)據(jù)庫查詢,然后把結(jié)果寫到緩存中。 Mybatis的內(nèi)部緩存使用一個(gè)HashMap,key為hashcode+statementId+sql語句。Value為查詢出來的結(jié)果集映射成的java對(duì)象。 SqlSession執(zhí)行insert、update、delete等操作commit后會(huì)清空該SQLSession緩存。
2.二級(jí)緩存 二級(jí)緩存是mapper級(jí)別的,Mybatis默認(rèn)是沒有開啟二級(jí)緩存的。 第一次調(diào)用mapper下的SQL去查詢用戶的信息,查詢到的信息會(huì)存放代該mapper對(duì)應(yīng)的二級(jí)緩存區(qū)域。 第二次調(diào)用namespace下的mapper映射文件中,相同的sql去查詢用戶信息,會(huì)去對(duì)應(yīng)的二級(jí)緩存內(nèi)取結(jié)果。
以上就是動(dòng)力節(jié)點(diǎn)小編介紹的"Mybatis一級(jí)緩存和二級(jí)緩存的區(qū)別",希望對(duì)大家有幫助,如有疑問,請(qǐng)?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為您服務(wù)。
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時(shí)間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請(qǐng)后,顧問老師會(huì)電話與您溝通安排學(xué)習(xí)