




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
主講人:吳佳云延遲符MyBatis一級(jí)緩存動(dòng)態(tài)SQL與關(guān)聯(lián)映射什么是MyBatis緩存在實(shí)際項(xiàng)目開發(fā)中,通常對(duì)數(shù)據(jù)庫(kù)查詢的性能要求很高,MyBatis中通過緩存機(jī)制來減輕數(shù)據(jù)庫(kù)壓力,提高數(shù)據(jù)庫(kù)性能。Mybatis的查詢緩存分為一級(jí)緩存和二級(jí)緩存,下面將分別對(duì)MyBatis的一級(jí)緩存和二級(jí)緩存進(jìn)行詳細(xì)講解。一級(jí)緩存在應(yīng)用運(yùn)行過程中,我們有可能在一次數(shù)據(jù)庫(kù)會(huì)話中,執(zhí)行多次查詢條件完全相同的SQL,MyBatis提供了一級(jí)緩存的方案優(yōu)化這部分場(chǎng)景。MyBatis的一級(jí)緩存是SqlSession級(jí)別的緩存,具體執(zhí)行過程如圖所示。一級(jí)緩存MyBatis的配置文件中,添加如下語(yǔ)句,就可以使用一級(jí)緩存。<settings>
<!--開啟MyBatis一級(jí)緩存-->
<settingname="localCacheScope"value="SESSION"/>
</settings>mybatis-config.xml其中value共有兩個(gè)選項(xiàng),SESSION或者STATEMENT,MyBatis默認(rèn)配置是SESSION級(jí)別,即在一個(gè)MyBatis會(huì)話中執(zhí)行的所有語(yǔ)句,都會(huì)共享這一個(gè)緩存。另一種是STATEMENT級(jí)別,可以理解為緩存只對(duì)當(dāng)前執(zhí)行的這一個(gè)Statement有效。一級(jí)緩存案例(1)數(shù)據(jù)庫(kù)準(zhǔn)備CREATETABLEtb_book(
`id`INTNOTNULLAUTO_INCREMENT,
`name`VARCHAR(45)NULL,
`price`DECIMAL(10,2)NULL,
PRIMARYKEY(`id`));
INSERTINTOtb_book(`id`,`name`,`price`)VALUES('1001','JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)','50.00');一級(jí)緩存案例(2)實(shí)體類@Data
publicclassBook{
/**id*/
privateIntegerid;
/**書名*/
privateStringname;
/**價(jià)格*/
privateBigDecimalprice;
}Book.java一級(jí)緩存案例(3)創(chuàng)建Mapper接口BookMapper.javapublicinterfaceBookMapper{
BookgetById(Integerid);
IntegerupdateBy(Bookbook);
}一級(jí)緩存案例(4)創(chuàng)建Mapper映射文件BookMapper.xml<mappernamespace="com.my.ccit.mapper.BookMapper">
<selectid="getById"resultType="com.my.ccit.entity.Book"parameterType="integer">
select*fromtb_book
whereid=#{id}
</select>
<updateid="updateBy"parameterType="com.my.ccit.entity.Book">
updatetb_book
<set>
<iftest="name!=null">name=#{name},</if>
<iftest="price!=null">price=#{price},</if>
</set>
whereid=#{id}
</update>
</mapper>一級(jí)緩存案例(5)log4j日志<!--日志log4j依賴包-->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>pom.xmlperties#全局日志配置
#log4j.rootLogger=DEBUG,stdout
log4j.rootLogger=stdout
#控制臺(tái)輸出配置
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE}%5p%c{1}:%L-%m%n一級(jí)緩存案例(6)
測(cè)試代碼/**測(cè)試一級(jí)緩存更新*/
@Test
publicvoidtest2(){
//1.通過工具類生成SqlSession1SqlSession2對(duì)象
SqlSessionsession=MyBatisUtils.getSession();
BookMapperbookMapper=session.getMapper(BookMapper.class);
//2.根據(jù)session查詢id=1001的圖書信息,并輸出信息
System.out.println("調(diào)用bookMapper.getById(1001)"+bookMapper.getById(1001));
System.out.println("調(diào)用bookMapper.getById(1001)"+bookMapper.getById(1001));
//3.更新id=1001的圖書信息
Bookparam=newBook();
param.setId(1001);
param.setPrice(newBigDecimal("66.66"));
System.out.println("更新信息:");
bookMapper.updateBy(param);
session.commit();
//4.根據(jù)session查詢id=1001的圖書信息,并輸出信息
System.out.println("通過session再次查詢信息:");
System.out.println("調(diào)用bookMapper
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 中級(jí)微觀經(jīng)濟(jì)學(xué)知到課后答案智慧樹章節(jié)測(cè)試答案2025年春浙江大學(xué)
- 2025年天一大聯(lián)考海南省高三2月英語(yǔ)試題模擬試題含解析
- 寧夏警官職業(yè)學(xué)院《外國(guó)民族音樂概論》2023-2024學(xué)年第一學(xué)期期末試卷
- 焦作大學(xué)《泰語(yǔ)口語(yǔ)》2023-2024學(xué)年第二學(xué)期期末試卷
- 江西理工大學(xué)《過程裝備集成科學(xué)與技術(shù)》2023-2024學(xué)年第二學(xué)期期末試卷
- 廣東海洋大學(xué)《紡織綠色制造》2023-2024學(xué)年第二學(xué)期期末試卷
- 四川省綿陽(yáng)市游仙區(qū)2025年數(shù)學(xué)五下期末檢測(cè)模擬試題含答案
- 上海市格致初級(jí)中學(xué)2025年高考模擬(4月)英語(yǔ)試題含解析
- 工傷認(rèn)定風(fēng)險(xiǎn)點(diǎn)和防范措施
- 2025年五氧化二磷行業(yè)政策分析:五氧化二磷行業(yè)標(biāo)準(zhǔn)規(guī)范行業(yè)發(fā)展
- 高等教育數(shù)字化轉(zhuǎn)型心得體會(huì)
- 2025年安徽財(cái)貿(mào)職業(yè)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試題庫(kù)及答案1套
- 2025年安徽職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試題庫(kù)及答案1套
- 日式保潔培訓(xùn)課件大全
- 2025年廣東省深圳市高考語(yǔ)文一模試卷
- 2025年陜西工商職業(yè)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試題庫(kù)學(xué)生專用
- 2025年福建省高職單招職業(yè)適應(yīng)性測(cè)試題庫(kù)及答案解析
- 自媒體運(yùn)營(yíng)實(shí)戰(zhàn)教程(抖音版) 課件 第7章 短視頻運(yùn)營(yíng)-自媒體中級(jí)
- 2025時(shí)事政治必考題庫(kù)含參考答案
- 保潔管理安全培訓(xùn)課件
- 小學(xué)生藥品安全課件視頻
評(píng)論
0/150
提交評(píng)論