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

mybatis 延遲加載的深入理解

 更新時間:2019年01月15日 14:53:55   作者:一號線  
這篇文章主要介紹了mybatis 延遲加載的深入理解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

什么是延遲加載

延遲加載又叫懶加載,也叫按需加載,也就是說先加載主信息,需要的時候,再去加載從信息。代碼中有查詢語句,當執(zhí)行到查詢語句時,并不是馬上去DB中查詢,而是根據(jù)設(shè)置的延遲策略將查詢向后推遲。

什么時候會執(zhí)行延遲加載

配置之后在對關(guān)聯(lián)對象進行查詢時使用延遲加載。

延遲加載策略

直接加載

遇到代碼中查詢語句,馬上到DB中執(zhí)行select語句進行查詢。(這種只能用于多表單獨查詢)

侵入式延遲加載

將關(guān)聯(lián)對象的詳情(具體數(shù)據(jù),如id、name)侵入到主加載對象,作為主加載對象的詳情的一部分出現(xiàn)。當要訪問主加載對象的詳情時才會查詢主表,但由于關(guān)聯(lián)對象詳情作為主加載對象的詳情一部分出現(xiàn),所以這個查詢不僅會查詢主表,還會查詢關(guān)聯(lián)表。

深度延遲加載

將關(guān)聯(lián)對象的詳情(具體數(shù)據(jù),如id、name)侵入到主加載對象,作為主加載對象的詳情的一部分出現(xiàn)。當要訪問主加載對象的詳情時才會查詢主表,但由于關(guān)聯(lián)對象詳情作為主加載對象的詳情一部分出現(xiàn),所以這個查詢不僅會查詢主表,還會查詢關(guān)聯(lián)表。

使用延遲加載的目的

減輕DB服務(wù)器的壓力,因為我們延遲加載只有在用到需要的數(shù)據(jù)才會執(zhí)行查詢操作。

如何開啟延遲加載功能

Mybatis的延遲加載功能默認是關(guān)閉的

需要在SqlMapConfig.xml文件中通過setting標簽配置來開啟延遲加載功能

開啟延遲加載的屬性:

  • lazyLoadingEnabled:全局性設(shè)置懶加載。如果設(shè)為‘false',則所有相關(guān)聯(lián)的都會被初始化加載。默認為false
  • aggressiveLazyLoading:當設(shè)置為‘true'的時候,懶加載的對象可能被任何懶屬性全部加載。否則,每個屬性都按需加載。默認為true

配置

  <settings>
    <setting name ="aggressiveLazyLoading" value="false"/>
    <!--開啟延遲加載-->
    <setting name="lazyLoadingEnabled" value="true"/>
  </settings>

我們用關(guān)聯(lián)查詢來實現(xiàn)延遲加載,假設(shè)我們現(xiàn)在要查出用戶和用戶角色。

首先我們在user中添加查詢userVo的方法和xml。

<!--userMapper.xml-->

....
<resultMap id="BaseResultMap" type="com.redstar.basemapper.pojo.User">
    <id column="id" jdbcType="VARCHAR" property="id"/>
    <result column="name" jdbcType="VARCHAR" property="name"/>
    <result column="age" jdbcType="INTEGER" property="age"/>
    <result column="role_id" jdbcType="INTEGER" property="roleId"/>
  </resultMap>
  <resultMap id="userRoleMapSelect" type="com.redstar.basemapper.pojo.UserVo">
    <association property="user" resultMap="BaseResultMap"/>
    <association property="role" fetchType="lazy" column="{id=role_id}"
           select="com.redstar.basemapper.dao.RoleMapper.getRoleById"/>
  </resultMap>
  <sql id="Base_Column_List">
  id, `name`, age, role_id
 </sql>
  <select id="getUserVo" resultMap="userRoleMapSelect">
   select * from user where id=#{userId}
  </select>
...
  
  
  
  <!--roleMapper.xml-->
...  
  <resultMap id="BaseResultMap" type="com.redstar.basemapper.pojo.Role">
  <id column="id" jdbcType="INTEGER" property="id" />
  <result column="role_name" jdbcType="VARCHAR" property="roleName" />
 </resultMap>
 <sql id="Base_Column_List">
  id, role_name
 </sql>
 <select id="getRoleById" resultMap="BaseResultMap">
  select * from role where id=#{id}
 </select>
... 

測試用例

@RunWith(SpringRunner.class)
@SpringBootTest
public class BaseMapperApplicationTests {
  @Autowired
  private UserMapper userMapper;

  @Autowired
  private RoleMapper roleMapper;

  @Test
  public void getUserVo() {
    System.out.println(userMapper.getUserVo("12312232"));
//    System.out.println(userMapper.getUserById("12312232"));
//    System.out.println(roleMapper.getRoleById(1));

  }
}

輸出結(jié)果:

UserVo{user=User [Hash = 1937575946, id=12312232, name=哇哈哈啊娃哈哈哇哈哈哈哈哈哈哈, age=48, roleId=1, serialVersionUID=1], role=Role [Hash = 317053574, id=1, roleName=admin, serialVersionUID=1]}

注意

許多對延遲加載原理不太熟悉的朋友會經(jīng)常遇到一些莫名其妙的問題:有些時候延遲加載可以得到數(shù)據(jù),有些時候延遲加載就會報錯,為什么會出現(xiàn)這種情況呢?

MyBatis 延遲加載是通過動態(tài)代理實現(xiàn)的,當調(diào)用配直為延遲加載的屬性方法時, 動態(tài)代理的操作會被觸發(fā),這些額外的操作就是通過 MyBatis 的 SqlSessio口去執(zhí)行嵌套 SQL 的 。由于在和某些框架集成時, SqlSession 的生命周期交給了框架來管理,因此當對象超出SqlSession 生命周期調(diào)用時,會由于鏈接關(guān)閉等問題而拋出異常 。 在和 Spring 集成時,要確保只能在 Service 層調(diào)用延遲加載的屬性 。 當結(jié)果從 Service 層返回至 Controller 層時, 如果獲取延遲加載的屬性值,會因為 SqlSessio口已經(jīng)關(guān)閉而拋出異常 。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot打成jar包瘦身方法總結(jié)

    SpringBoot打成jar包瘦身方法總結(jié)

    springBoot打包的時候代碼和jar包打包在同一個jar包里面,會導致jar包非常龐大,下面這篇文章主要給大家介紹了關(guān)于SpringBoot打的jar包瘦身方法的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • Dubbo服務(wù)校驗參數(shù)的解決方案

    Dubbo服務(wù)校驗參數(shù)的解決方案

    這篇文章主要介紹了Dubbo服務(wù)如何優(yōu)雅的校驗參數(shù),Dubbo框架本身是支持參數(shù)校驗的,同時也是基于JSR303去實現(xiàn)的,今天通過示例代碼介紹下詳細實現(xiàn)過程,需要的朋友可以參考下
    2022-03-03
  • 詳解Spring boot/Spring 統(tǒng)一錯誤處理方案的使用

    詳解Spring boot/Spring 統(tǒng)一錯誤處理方案的使用

    這篇文章主要介紹了詳解Spring boot/Spring 統(tǒng)一錯誤處理方案的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • Linux系統(tǒng)下搭建Java開發(fā)環(huán)境

    Linux系統(tǒng)下搭建Java開發(fā)環(huán)境

    本文主要是記錄了如何在Linux環(huán)境下一步步安裝JAVA JDK環(huán)境,非常簡單實用,有需要的朋友可以參考下
    2014-10-10
  • Spring依賴注入中的@Resource與@Autowired詳解

    Spring依賴注入中的@Resource與@Autowired詳解

    這篇文章主要介紹了Spring依賴注入中的@Resource與@Autowired詳解,提到Spring依賴注入,大家最先想到應該是@Resource和@Autowired,對于Spring為什么要支持兩個這么類似的注解卻未提到,屬于知其然而不知其所以然,本文就來做詳細講解,需要的朋友可以參考下
    2023-09-09
  • JVM常見垃圾收集器學習指南

    JVM常見垃圾收集器學習指南

    這篇文章主要為大家介紹了JVM常見垃圾收集器學習指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • java實現(xiàn)登錄驗證碼

    java實現(xiàn)登錄驗證碼

    這篇文章主要為大家詳細介紹了java實現(xiàn)登錄驗證碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • Java和C#輸入輸出流的方法(詳解)

    Java和C#輸入輸出流的方法(詳解)

    下面小編就為大家?guī)硪黄狫ava和C#輸入輸出流的方法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • Spring整合MyBatis圖示過程解析

    Spring整合MyBatis圖示過程解析

    這篇文章主要介紹了Spring整合MyBatis圖示過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • java如何根據(jù)IP獲取當前區(qū)域天氣信息詳解

    java如何根據(jù)IP獲取當前區(qū)域天氣信息詳解

    根據(jù)IP自動獲取當?shù)氐奶鞖忸A報信息這個功能大家應該都遇到過,天氣預報信息用途非常廣泛,篇文章主要給大家介紹了關(guān)于java如何根據(jù)IP獲取當前區(qū)域天氣信息的相關(guān)資料,需要的朋友可以參考下
    2021-08-08

最新評論