mybatis教程之延遲加載詳解
延遲加載
1 使用延遲加載意義
在進(jìn)行數(shù)據(jù)查詢時(shí),為了提高數(shù)據(jù)庫(kù)查詢性能,盡量使用單表查詢,因?yàn)閱伪聿樵儽榷啾黻P(guān)聯(lián)查詢速度要快。
如果查詢單表就可以滿足需求,一開始先查詢單表,當(dāng)需要關(guān)聯(lián)信息時(shí),再關(guān)聯(lián)查詢,當(dāng)需要關(guān)聯(lián)信息再查詢這個(gè)叫延遲加載。
mybatis中resultMap提供延遲加載功能,通過(guò)resultMap配置延遲加載。
2 配置mybatis支持延遲加載
在 SqlMapConfig.xml中配置全局參數(shù):
<!-- 全局配置參數(shù) --> <settings> <!-- 延遲加載總開關(guān) --> <setting name="lazyLoadingEnabled" value="true" /> <!-- 設(shè)置按需加載 --> <setting name="aggressiveLazyLoading" value="false" /> </settings>
3 延遲加載實(shí)現(xiàn)
3.1 實(shí)現(xiàn)思路
需求:
查詢訂單及用戶的信息,一對(duì)一查詢。
剛開始只查詢訂單信息
當(dāng)需要用戶時(shí)調(diào)用 Orders類中的getUser()方法執(zhí)行延遲加載 ,向數(shù)據(jù)庫(kù)發(fā)出sql。
3.2 mapper.xml
<!-- 一對(duì)一查詢延遲加載 開始只查詢訂單,對(duì)用戶信息進(jìn)行延遲加載 --> <select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading"> SELECT orders.* FROM orders </select>
3.3 resultMap
<!-- 一對(duì)一查詢延遲加載 的配置 --> <resultMap type="orders" id="orderCustomLazyLoading"> <!-- 完成了訂單信息的映射配置 --> <!-- id:訂單關(guān)聯(lián)用戶查詢的唯 一 標(biāo)識(shí) --> <id column="id" property="id" /> <result column="user_id" property="userId" /> <result column="number" property="number" /> <result column="createtime" property="createtime" /> <result column="note" property="note" /> <!-- 配置用戶信息的延遲加載 select:延遲加載執(zhí)行的sql所在的statement的id,如果不在同一個(gè)namespace需要加namespace sql:根據(jù)用戶id查詢用戶信息 column:關(guān)聯(lián)查詢的列 property:將關(guān)聯(lián)查詢的用戶信息設(shè)置到Orders的哪個(gè)屬性 --> <association property="user" select="com.sihai.mybatis.mapper.UserMapper.findUserById" column="user_id"></association> </resultMap>
3.4 mapper.java
//一對(duì)一查詢,延遲加載 public List<Orders> findOrderUserListLazyLoading() throws Exception;
3.5 測(cè)試代碼
// 一對(duì)一查詢延遲加載 @Test public void testFindOrderUserListLazyLoading() throws Exception { SqlSession sqlSession = sqlSessionFactory.openSession(); // 創(chuàng)建mapper代理對(duì)象 OrdersMapperCustom ordersMapperCustom = sqlSession .getMapper(OrdersMapperCustom.class); // 調(diào)用方法 List<Orders> list = ordersMapperCustom.findOrderUserListLazyLoading(); //這里執(zhí)行延遲加載,要發(fā)出sql User user = list.get(0).getUser(); System.out.println(user); }
4 resultType、resultMap、延遲加載使用場(chǎng)景總結(jié)
4.1 延遲加載:
延遲加載實(shí)現(xiàn)的方法多種多樣,在只查詢單表就可以滿足需求,為了提高數(shù)據(jù)庫(kù)查詢性能使用延遲加載,再查詢關(guān)聯(lián)信息。
mybatis提供延遲加載的功能用于service層。
4.2 resultType:
作用:將查詢結(jié)果按照sql列名pojo屬性名一致性映射到pojo中。
場(chǎng)合:常見一些明細(xì)記錄的展示,將關(guān)聯(lián)查詢信息全部展示在頁(yè)面時(shí),此時(shí)可直接使用resultType將每一條記錄映射到pojo中,在前端頁(yè)面遍歷list(list中是pojo)即可。
4.3 resultMap:
使用association和collection完成一對(duì)一和一對(duì)多高級(jí)映射。
4.4 association:
作用:將關(guān)聯(lián)查詢信息映射到一個(gè)pojo類中。
場(chǎng)合:為了方便獲取關(guān)聯(lián)信息可以使用association將關(guān)聯(lián)訂單映射為pojo,比如:查詢訂單及關(guān)聯(lián)用戶信息。
4.5 collection:
作用:將關(guān)聯(lián)查詢信息映射到一個(gè)list集合中。
場(chǎng)合:為了方便獲取關(guān)聯(lián)信息可以使用collection將關(guān)聯(lián)信息映射到list集合中,比如:查詢用戶權(quán)限范圍模塊和功能,可使用collection將模塊和功能列表映射到list中。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java接口操作(繼承父類并實(shí)現(xiàn)多個(gè)接口)
這篇文章主要介紹了Java接口操作(繼承父類并實(shí)現(xiàn)多個(gè)接口),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10Java享元設(shè)計(jì)模式優(yōu)化對(duì)象創(chuàng)建提高性能和效率
Java享元設(shè)計(jì)模式通過(guò)共享可重用的對(duì)象,減少了系統(tǒng)中對(duì)象的數(shù)量,優(yōu)化了對(duì)象的創(chuàng)建和管理,提高了性能和效率。它是一種經(jīng)典的設(shè)計(jì)模式,適用于需要處理大量相似對(duì)象的應(yīng)用程序2023-04-04去掉IntelliJ IDEA 中 mybatis 對(duì)應(yīng)的 xml 文件警告的教程圖解
本文通過(guò)圖文并茂的形式給大家介紹了去掉IntelliJ IDEA 中 mybatis 對(duì)應(yīng)的 xml 文件警告的教程,需要的朋友可以參考下2018-06-06把Java程序轉(zhuǎn)換成exe,可直接運(yùn)行的實(shí)現(xiàn)
這篇文章主要介紹了把Java程序轉(zhuǎn)換成exe,可直接運(yùn)行的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09淺析JavaMail發(fā)送郵件后再通過(guò)JavaMail接收格式問(wèn)題
這篇文章主要介紹了JavaMail發(fā)送郵件后再通過(guò)JavaMail接收格式問(wèn)題 ,本文通過(guò)代碼實(shí)例給大家詳細(xì)解說(shuō),需要的朋友可以參考下2019-06-06GSON實(shí)現(xiàn)Java對(duì)象的JSON序列化與反序列化的實(shí)例教程
GSON是Google開發(fā)并開源的一個(gè)Java的JSON轉(zhuǎn)換庫(kù),這里我們將來(lái)講解GSON實(shí)現(xiàn)Java對(duì)象的JSON序列化與反序列化的實(shí)例教程,需要的朋友可以參考下2016-06-06java算法實(shí)現(xiàn)預(yù)測(cè)雙色球中獎(jiǎng)號(hào)碼
這篇文章主要介紹了java算法實(shí)現(xiàn)預(yù)測(cè)雙色球中獎(jiǎng)號(hào)碼的相關(guān)資料,需要的朋友可以參考下2015-12-12Java NIO:淺析IO模型_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
在進(jìn)入Java NIO編程之前,我們今天先來(lái)討論一些比較基礎(chǔ)的知識(shí):I/O模型。對(duì)java io nio相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2017-05-05