JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課3-9:MyBatis一級(jí)緩存_第1頁(yè)
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課3-9:MyBatis一級(jí)緩存_第2頁(yè)
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課3-9:MyBatis一級(jí)緩存_第3頁(yè)
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課3-9:MyBatis一級(jí)緩存_第4頁(yè)
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課3-9:MyBatis一級(jí)緩存_第5頁(yè)
已閱讀5頁(yè),還剩6頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論