mybatis教程之延遲加載詳解
延遲加載
1 使用延遲加載意義
在進(jìn)行數(shù)據(jù)查詢時,為了提高數(shù)據(jù)庫查詢性能,盡量使用單表查詢,因為單表查詢比多表關(guān)聯(lián)查詢速度要快。
如果查詢單表就可以滿足需求,一開始先查詢單表,當(dāng)需要關(guān)聯(lián)信息時,再關(guān)聯(lián)查詢,當(dāng)需要關(guān)聯(lián)信息再查詢這個叫延遲加載。
mybatis中resultMap提供延遲加載功能,通過resultMap配置延遲加載。
2 配置mybatis支持延遲加載

在 SqlMapConfig.xml中配置全局參數(shù):
<!-- 全局配置參數(shù) --> <settings> <!-- 延遲加載總開關(guān) --> <setting name="lazyLoadingEnabled" value="true" /> <!-- 設(shè)置按需加載 --> <setting name="aggressiveLazyLoading" value="false" /> </settings>
3 延遲加載實現(xiàn)
3.1 實現(xiàn)思路
需求:
查詢訂單及用戶的信息,一對一查詢。
剛開始只查詢訂單信息
當(dāng)需要用戶時調(diào)用 Orders類中的getUser()方法執(zhí)行延遲加載 ,向數(shù)據(jù)庫發(fā)出sql。
3.2 mapper.xml
<!-- 一對一查詢延遲加載
開始只查詢訂單,對用戶信息進(jìn)行延遲加載
-->
<select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading">
SELECT
orders.*
FROM
orders
</select>
3.3 resultMap
<!-- 一對一查詢延遲加載 的配置 -->
<resultMap type="orders" id="orderCustomLazyLoading">
<!-- 完成了訂單信息的映射配置 -->
<!-- id:訂單關(guān)聯(lián)用戶查詢的唯 一 標(biāo)識 -->
<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,如果不在同一個namespace需要加namespace
sql:根據(jù)用戶id查詢用戶信息 column:關(guān)聯(lián)查詢的列 property:將關(guān)聯(lián)查詢的用戶信息設(shè)置到Orders的哪個屬性 -->
<association property="user"
select="com.sihai.mybatis.mapper.UserMapper.findUserById" column="user_id"></association>
</resultMap>
3.4 mapper.java
//一對一查詢,延遲加載 public List<Orders> findOrderUserListLazyLoading() throws Exception;
3.5 測試代碼
// 一對一查詢延遲加載
@Test
public void testFindOrderUserListLazyLoading() throws Exception {
SqlSession sqlSession = sqlSessionFactory.openSession();
// 創(chuàng)建mapper代理對象
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、延遲加載使用場景總結(jié)
4.1 延遲加載:
延遲加載實現(xiàn)的方法多種多樣,在只查詢單表就可以滿足需求,為了提高數(shù)據(jù)庫查詢性能使用延遲加載,再查詢關(guān)聯(lián)信息。
mybatis提供延遲加載的功能用于service層。
4.2 resultType:
作用:將查詢結(jié)果按照sql列名pojo屬性名一致性映射到pojo中。
場合:常見一些明細(xì)記錄的展示,將關(guān)聯(lián)查詢信息全部展示在頁面時,此時可直接使用resultType將每一條記錄映射到pojo中,在前端頁面遍歷list(list中是pojo)即可。
4.3 resultMap:
使用association和collection完成一對一和一對多高級映射。
4.4 association:
作用:將關(guān)聯(lián)查詢信息映射到一個pojo類中。
場合:為了方便獲取關(guān)聯(lián)信息可以使用association將關(guān)聯(lián)訂單映射為pojo,比如:查詢訂單及關(guān)聯(lián)用戶信息。
4.5 collection:
作用:將關(guān)聯(lián)查詢信息映射到一個list集合中。
場合:為了方便獲取關(guān)聯(lián)信息可以使用collection將關(guān)聯(lián)信息映射到list集合中,比如:查詢用戶權(quán)限范圍模塊和功能,可使用collection將模塊和功能列表映射到list中。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Springboot下使用Redis管道(pipeline)進(jìn)行批量操作
本文主要介紹了Spring?boot?下使用Redis管道(pipeline)進(jìn)行批量操作,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
spring?security需求分析與基礎(chǔ)環(huán)境準(zhǔn)備教程
這篇文章主要為大家介紹了spring?security需求分析與基礎(chǔ)環(huán)境準(zhǔn)備教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03
Spring Boot利用Java Mail實現(xiàn)郵件發(fā)送
這篇文章主要為大家詳細(xì)介紹了Spring Boot利用Java Mail實現(xiàn)郵件發(fā)送,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-02-02
SpringBoot中Mybatis + Druid 數(shù)據(jù)訪問的詳細(xì)過程
Spring Boot 底層都是采用 SpringData 的方式進(jìn)行統(tǒng)一處理各種數(shù)據(jù)庫,SpringData也是Spring中與SpringBoot、SpringCloud 等齊名的知名項目,下面看下SpringBoot Mybatis Druid數(shù)據(jù)訪問的詳細(xì)過程,感興趣的朋友一起看看吧2021-11-11

