1 使用延遲加載意義
在進行數據查詢時,為了提高數據庫查詢性能,盡量使用單表查詢,因為單表查詢比多表關聯查詢速度要快。
如果查詢單表就可以滿足需求,一開始先查詢單表,當需要關聯信息時,再關聯查詢,當需要關聯信息再查詢這個叫延遲加載。
mybatis中resultMap提供延遲加載功能,通過resultMap配置延遲加載。
2 配置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