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

mybatis?查詢方式與效率高低對(duì)比

 更新時(shí)間:2023年03月15日 14:17:25   作者:遇見的昨天  
這篇文章主要介紹了mybatis?查詢方式與效率高低對(duì)比,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

mybatis查詢方式與效率高低

<!--
? ? ?一對(duì)一關(guān)聯(lián)查詢
? ? ?select s.id,s.name,s.age,t.name tname ?from student s,teacher t where s.tid=t.id;
? ? ? -->

? ? <!--
? ? ? ? 關(guān)聯(lián)的嵌套 Select 查詢
? ? 問題:
? ? ? ? 這種方式雖然很簡(jiǎn)單,但在大型數(shù)據(jù)集或大型數(shù)據(jù)表上表現(xiàn)不佳。這個(gè)問題被稱為“N+1 查詢問題”。 概括地講,N+1 查詢問題是這樣子的:
? ? ? ? ? ? 你執(zhí)行了一個(gè)單獨(dú)的 SQL 語句來獲取結(jié)果的一個(gè)列表(就是“+1”)。
? ? ? ? ? ? 對(duì)列表返回的每條記錄,你執(zhí)行一個(gè) select 查詢語句來為每條記錄加載詳細(xì)信息(就是“N”)。
? ? 解決:
? ? ? ? MyBatis 能夠?qū)@樣的查詢進(jìn)行延遲加載,因此可以將大量語句同時(shí)運(yùn)行的開銷分散開來。
? ? ? ? (例如: 我需要teacher這個(gè)對(duì)象的時(shí)候就會(huì)進(jìn)行加載,如果不需要就不會(huì)立即加載(延遲加載))
? ? ? ? ?然而,如果你加載記錄列表之后立刻就遍歷列表以獲取嵌套的數(shù)據(jù),就會(huì)觸發(fā)所有的延遲加載查詢,性能可能會(huì)變得很糟糕。
? ? -->
? ? <!-- ?關(guān)聯(lián)的嵌套 Select 查詢 ?-->
? ? <resultMap id="studentMap" type="student">
? ? ? ? <id property="id" column="id"/>
? ? ? ? <result property="name" column="name"/>
? ? ? ? <result property="age" column="age"/>
? ? ? ? <association property="teacher" column="tid" javaType="teacher" select="selectTeacherById">
? ? ? ? </association>
? ? </resultMap>

? ? <select id="findAll" resultMap="studentMap">
? ? ? ? select * from student;
? ? </select>
? ? <select id="selectTeacherById" parameterType="int" resultType="teacher" ?>
? ? ? ? select * from ?teacher where id=#{id};
? ? </select>


? ? <!--
? ? ? ? 關(guān)聯(lián)的嵌套 ?結(jié)果映射
?? ??? ?將結(jié)果直接映射 到實(shí)體類中
? ? ? ? 第二種 方式效率比第一種 速度更高
? ? ?-->
? ? <resultMap id="studentMap1" type="student">
? ? ? ? <id property="id" column="id"/>
? ? ? ? <result property="name" column="name"/>
? ? ? ? <result property="age" column="age"/>
? ? ? ? <association property="teacher" javaType="teacher">
? ? ? ? ? ? <id property="id" column="tid"/>
? ? ? ? ? ? <result property="name" column="tname"/>
? ? ? ? </association>
? ? </resultMap>
? ? <select id="selectAll" resultMap="studentMap1">
? ? ? ? select s.id,s.name,s.age,t.name tname ,t.id tid from student s,teacher t where s.tid=t.id;
? ? </select>

------------------------------------------------------------------
<!-- ?一對(duì)多 ?關(guān)聯(lián)嵌套 ?結(jié)果映射 ? ?ofType 將數(shù)據(jù)封裝到指定的泛型 ?-->
? ? <resultMap id="teacherMap" type="teacher">
? ? ? ? <id property="id" column="id"/>
? ? ? ? <result property="name" column="name"/>
? ? ? ? <collection property="students" ofType="student" >
? ? ? ? ? ? <id property="id" column="sid"/>
? ? ? ? ? ? <result property="name" column="sname"/>
? ? ? ? ? ? <result property="age" column="sage"/>
? ? ? ? ? ? <result property="tid" column="stid"/>
? ? ? ? </collection>
? ? </resultMap>
? ? <select id="selectTeacherById" ?parameterType="int" ?resultMap="teacherMap">
? ? ? ? ?select t.id ,t.name,s.id sid,s.name sname,s.age sage,s.tid stid
? ? ? ? ?from student s ,teacher t
? ? ? ? ?where s.tid=t.id and t.id=1;
? ? </select>

mybatis提高查詢效率的方式

緩存機(jī)制

1 一級(jí)緩存:

當(dāng)mysql連續(xù)執(zhí)行兩次select * from table where id =1;第一次會(huì)執(zhí)行sql語句查詢數(shù)據(jù)庫,然后保存到sqlsession緩存,第二次查詢會(huì)先從緩存里查找,有的話直接返回不會(huì)執(zhí)行sql.

但是如果兩次sql中間增加一次commit操作(insert,delete,update),如:

select * from table where id =1
update table set name = zjw where id =1;
select * from table where id =1

這個(gè)時(shí)候第一次查詢依然會(huì)執(zhí)行sql查詢數(shù)據(jù)庫,但是在執(zhí)行完update后會(huì)清空sqlsession里的緩存,原因是避免臟讀,

所以第二次select在緩存里找不到數(shù)據(jù),又會(huì)執(zhí)行sql查詢數(shù)據(jù)庫。

2 二級(jí)緩存:

二級(jí)緩存是基于mapper文件的namaspace,對(duì)該mapper的所有sqlsession都共享一個(gè)二級(jí)緩存,如果兩個(gè)mapper的namespace一致,則兩個(gè)mapper的所有sqlsession共用一個(gè)二級(jí)緩存,

步驟:

在全局配置文件mybatis-configuration.xml加入

其次在mapper文件開啟緩存 type里面是緩存類。如果不寫是默認(rèn)的mabatis緩存類,自定義緩存類必須實(shí)現(xiàn)cache接口

需要緩存的pojo實(shí)體類要實(shí)現(xiàn)serializable接口,因?yàn)樵诰彺嬷腥〕鰯?shù)據(jù)映射到pojo類需要反序列化。

不同的兩個(gè)sqlsession查詢走二級(jí)緩存,但是如果其中有一個(gè)commit操作,為避免臟讀二級(jí)緩存還是會(huì)被清空。

在每個(gè)sql語句上使用useCache=true/false是否使用緩存,flushcache=true/false是否刷新緩存 ,在每次的commit后默認(rèn)刷新緩存。

懶加載

Mybatis中resultmap可以實(shí)現(xiàn)高級(jí)映射,association一對(duì)一,Collection一對(duì)多具有延遲加載功能

在collection或association中fetchtype=lazy,即為懶加載

在查詢主表時(shí),不會(huì)把子集查出來,直到子集用到的情況才會(huì)查出子集。

總結(jié)

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

相關(guān)文章

  • 分布式服務(wù)Dubbo+Zookeeper安全認(rèn)證實(shí)例

    分布式服務(wù)Dubbo+Zookeeper安全認(rèn)證實(shí)例

    下面小編就為大家分享一篇分布式服務(wù)Dubbo+Zookeeper安全認(rèn)證實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • IDEA中Javaweb項(xiàng)目圖片加載不出來解決方案

    IDEA中Javaweb項(xiàng)目圖片加載不出來解決方案

    在IDEA中能夠正常的預(yù)覽到圖片,但是在生成項(xiàng)目的war包時(shí),項(xiàng)目的目錄結(jié)構(gòu)卻會(huì)發(fā)生變化,所以無法訪問圖片,本文主要介紹了IDEA中Javaweb項(xiàng)目圖片加載不出來解決方案,感興趣的可以了解一下
    2023-10-10
  • springboot結(jié)合mysql主從來實(shí)現(xiàn)讀寫分離的方法示例

    springboot結(jié)合mysql主從來實(shí)現(xiàn)讀寫分離的方法示例

    這篇文章主要介紹了springboot結(jié)合mysql主從來實(shí)現(xiàn)讀寫分離的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Java實(shí)現(xiàn)PDF轉(zhuǎn)為線性PDF詳解

    Java實(shí)現(xiàn)PDF轉(zhuǎn)為線性PDF詳解

    線性化PDF文件是PDF文件的一種特殊格式,可以通過Internet更快地進(jìn)行查看。本文將通過后端Java程序?qū)崿F(xiàn)將PDF文件轉(zhuǎn)為線性化PDF。感興趣的可以了解一下
    2021-12-12
  • Java設(shè)計(jì)模式之單態(tài)模式(Singleton模式)介紹

    Java設(shè)計(jì)模式之單態(tài)模式(Singleton模式)介紹

    這篇文章主要介紹了Java設(shè)計(jì)模式之單態(tài)模式(Singleton模式)介紹,本文講解了如何使用單例模式、使用單例模式注意事項(xiàng)等內(nèi)容,需要的朋友可以參考下
    2015-03-03
  • 淺談Spring Cloud Eureka 自我保護(hù)機(jī)制

    淺談Spring Cloud Eureka 自我保護(hù)機(jī)制

    這篇文章主要介紹了淺談Spring Cloud Eureka 自我保護(hù)機(jī)制,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • mybatis?plus自動(dòng)生成代碼的示例代碼

    mybatis?plus自動(dòng)生成代碼的示例代碼

    本文主要介紹了mybatis?plus自動(dòng)生成代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • springboot學(xué)習(xí)筆記之 profile多環(huán)境配置切換的實(shí)現(xiàn)方式

    springboot學(xué)習(xí)筆記之 profile多環(huán)境配置切換的實(shí)現(xiàn)方式

    這篇文章主要介紹了springboot profile多環(huán)境配置切換的實(shí)現(xiàn)方式,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-07-07
  • SpringSecurity的防Csrf攻擊實(shí)現(xiàn)代碼解析

    SpringSecurity的防Csrf攻擊實(shí)現(xiàn)代碼解析

    這篇文章主要介紹了SpringSecurity的防Csrf攻擊實(shí)現(xiàn)代碼解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • Mybatis動(dòng)態(tài)sql超詳細(xì)講解

    Mybatis動(dòng)態(tài)sql超詳細(xì)講解

    動(dòng)態(tài)SQL是MyBatis的強(qiáng)大特性之一,顧名思義就是會(huì)動(dòng)的SQL,即是能夠靈活的根據(jù)某種條件拼接出完整的SQL語句,下面這篇文章主要給大家介紹了關(guān)于Mybatis動(dòng)態(tài)sql的相關(guān)資料,需要的朋友可以參考下
    2023-04-04

最新評(píng)論