一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - mybatis教程之延遲加載詳解

mybatis教程之延遲加載詳解

2020-09-22 10:42SIHAIloveYAN Java教程

本篇文章主要介紹了mybatis教程之延遲加載詳解。詳細介紹了延遲加載的意義和用法實現,有興趣的可以了解一下

延遲加載

1 使用延遲加載意義

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

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

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

2 配置mybatis支持延遲加載

mybatis教程之延遲加載詳解

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
<!-- 全局配置參數 -->
 
<settings>
 
<!-- 延遲加載總開關 -->
 
<setting name="lazyLoadingEnabled" value="true" />
 
<!-- 設置按需加載 -->
 
<setting name="aggressiveLazyLoading" value="false" />
 
</settings>

3 延遲加載實現

3.1 實現思路

需求:

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

剛開始只查詢訂單信息

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

3.2 mapper.xml

?
1
2
3
4
5
6
7
8
9
<!-- 一對一查詢延遲加載
   開始只查詢訂單,對用戶信息進行延遲加載 
   -->
   <select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading">
     SELECT 
     orders.*
    FROM
     orders
   </select>

3.3 resultMap 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<!-- 一對一查詢延遲加載 的配置 -->
  <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:延遲加載執行的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

?
1
2
//一對一查詢,延遲加載
  public List<Orders> findOrderUserListLazyLoading() throws Exception;

3.5 測試代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// 一對一查詢延遲加載
  @Test
  public void testFindOrderUserListLazyLoading() throws Exception {
 
    SqlSession sqlSession = sqlSessionFactory.openSession();
    // 創建mapper代理對象
    OrdersMapperCustom ordersMapperCustom = sqlSession
        .getMapper(OrdersMapperCustom.class);
 
    // 調用方法
    List<Orders> list = ordersMapperCustom.findOrderUserListLazyLoading();
     
    //這里執行延遲加載,要發出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中。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://blog.csdn.net/sihai12345/article/details/70477794?utm_source=tuicool&utm_medium=referral

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 青青草影院在线观看 | 成年视频在线观看 | 欧美日韩一区二区三区韩大 | 饭冈加奈子黑人解禁在线播放 | 深夜www| 男人狂躁女人下面的视频免费 | 日本韩国推理片免费观看网站 | 高跟丝袜人妖sissy露出调教 | 久久精品视频uu | 韩国成人毛片aaa黄 含羞草国产亚洲精品岁国产精品 | 人人澡 人人澡碰人人看软件 | 91精品国产91热久久久久福利 | 人与动人物性行为zozo共患病 | 久久这里只有精品视频9 | 精品一区在线 | 白丝校花好湿好紧 | 久久两性视频 | 午夜片神马影院福利 | 久草色视频 | 国产精品一区二区三区免费视频 | 拿捏小说| 赤坂丽女医bd无删减在线观看 | 国产成人精品1024在线 | 国产成人愉拍精品 | 欧美男同video | 猛操女人| 高h孕交| 亚洲一区二区福利视频 | 公翁的舌尖研磨她的花蒂小说 | 美女扒开胸罩露出胸大乳 | 精品一区二区三区视频 | 国产免费看片 | 99re热这里只有精品视频 | 500福利第一巨人导航 | 天天久久影视色香综合网 | 免费在线中文字幕 | 四虎永久在线精品波多野结衣 | 久久国产精品无码视欧美 | 无码人妻丰满熟妇啪啪网不卡 | 亚洲男人的天堂视频 | 国产精品视频色拍拍 |