欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis教程之延遲加載詳解

 更新時(shí)間:2017年05月03日 09:17:22   作者:SIHAIloveYAN  
本篇文章主要介紹了mybatis教程之延遲加載詳解。詳細(xì)介紹了延遲加載的意義和用法實(shí)現(xiàn),有興趣的可以了解一下

延遲加載

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)文章

最新評(píng)論