内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

mybatis教程之延遲加載詳解

延遲加載

創(chuàng)新互聯是一家專業(yè)提供金臺企業(yè)網站建設,專注與成都網站設計、網站制作、H5高端網站建設、小程序制作等業(yè)務。10年已為金臺眾多企業(yè)、政府機構等服務。創(chuàng)新互聯專業(yè)網站設計公司優(yōu)惠進行中。

1 使用延遲加載意義

在進行數據查詢時,為了提高數據庫查詢性能,盡量使用單表查詢,因為單表查詢比多表關聯查詢速度要快。

如果查詢單表就可以滿足需求,一開始先查詢單表,當需要關聯信息時,再關聯查詢,當需要關聯信息再查詢這個叫延遲加載。 

mybatis中resultMap提供延遲加載功能,通過resultMap配置延遲加載。

2 配置mybatis支持延遲加載

mybatis教程之延遲加載詳解

在 SqlMapConfig.xml中配置全局參數:

<!-- 全局配置參數 --> 
 
<settings> 
 
<!-- 延遲加載總開關 --> 
 
<setting name="lazyLoadingEnabled" value="true" /> 
 
<!-- 設置按需加載 --> 
 
<setting name="aggressiveLazyLoading" value="false" /> 
 
</settings> 

3 延遲加載實現

3.1 實現思路

需求:

查詢訂單及用戶的信息,一對一查詢。

剛開始只查詢訂單信息

當需要用戶時調用 Orders類中的getUser()方法執(zhí)行延遲加載 ,向數據庫發(fā)出sql。

3.2 mapper.xml

<!-- 一對一查詢延遲加載 
   開始只查詢訂單,對用戶信息進行延遲加載  
   --> 
   <select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading"> 
     SELECT  
     orders.* 
    FROM 
     orders 
   </select> 

3.3 resultMap 

<!-- 一對一查詢延遲加載 的配置 --> 
  <resultMap type="orders" id="orderCustomLazyLoading"> 
    <!-- 完成了訂單信息的映射配置 --> 
    <!-- id:訂單關聯用戶查詢的唯 一 標識 --> 
    <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:根據用戶id查詢用戶信息 column:關聯查詢的列 property:將關聯查詢的用戶信息設置到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); 
 
    // 調用方法 
    List<Orders> list = ordersMapperCustom.findOrderUserListLazyLoading(); 
     
    //這里執(zhí)行延遲加載,要發(fā)出sql 
    User user = list.get(0).getUser(); 
    System.out.println(user); 
     
  } 

4 resultType、resultMap、延遲加載使用場景總結

4.1 延遲加載:

延遲加載實現的方法多種多樣,在只查詢單表就可以滿足需求,為了提高數據庫查詢性能使用延遲加載,再查詢關聯信息。
mybatis提供延遲加載的功能用于service層。

4.2 resultType:

作用:將查詢結果按照sql列名pojo屬性名一致性映射到pojo中。

場合:常見一些明細記錄的展示,將關聯查詢信息全部展示在頁面時,此時可直接使用resultType將每一條記錄映射到pojo中,在前端頁面遍歷list(list中是pojo)即可。

4.3 resultMap:

使用association和collection完成一對一和一對多高級映射。

4.4 association:

作用:將關聯查詢信息映射到一個pojo類中。

場合:為了方便獲取關聯信息可以使用association將關聯訂單映射為pojo,比如:查詢訂單及關聯用戶信息。

4.5 collection:

作用:將關聯查詢信息映射到一個list集合中。

場合:為了方便獲取關聯信息可以使用collection將關聯信息映射到list集合中,比如:查詢用戶權限范圍模塊和功能,可使用collection將模塊和功能列表映射到list中。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯。

文章標題:mybatis教程之延遲加載詳解
分享URL:http://www.rwnh.cn/article24/ghcsce.html

成都網站建設公司_創(chuàng)新互聯,為您提供網站營銷網站收錄、外貿網站建設、響應式網站做網站

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

網站托管運營
荣成市| 雷山县| 玛多县| 海淀区| 西平县| 东山县| 普宁市| 鱼台县| 宁南县| 丰宁| 洪雅县| 平果县| 庆云县| 常山县| 新龙县| 石棉县| 株洲市| 太仓市| 嘉定区| 武汉市| 奉化市| 博爱县| 安国市| 乌兰县| 泰安市| 革吉县| 洪泽县| 格尔木市| 曲周县| 杭锦旗| 普兰店市| 台东市| 凌源市| 澄城县| 望江县| 江油市| 小金县| 甘德县| 南部县| 云安县| 资阳市|