• JavaEE Mybatis(四)延迟加载


    1. 延迟加载

    什么是延迟加载?延迟加载 的反义词就是 立即加载,

    立即加载 是指在取得“省”对象时(此处的数据库表:省包含市),省中所有的“市”对象都已经提取到内存中,因此其非常耗费 CPU 和内存资源。有时只需要省信息,而并不需要市信息,但立即加载还是把市信息也一同提取出来,这样的情况下就要使用延迟加载了。

    延迟加载 就是在使用到市对象时,再把其加载到内存中来,如果不使用市对象,就不加载到内存中,这就是延迟加载特性。

    2. 默认立即加载策略

    MyBatis 默认的行为就是 立即加载。

    当在程序中 调用到 List 中的 Userinfo 对象时,就采取了立即加载策略,立即将 Userinfo 对应的对象加载到内存中。

    3. 使用全局延迟加载策略与两种加载方式

    在配置文件中使用如下配置代码开始延迟加载:

    <settings>
          <setting name="logImpl" value="LOG4J" />
          <setting name="lazyLoadingEnable" value="true" />
    </settings>
    

    但延迟加载具体的实现方式分为两种。

    (1)获得子表时再进行加载。

    (2)打印主表信息时加载子表。

    这两种延迟加载的方式可以使用以下配置来进行切换,默认情况时第一种:

    <settings>
          <setting name="aggressiveLazyLoading" value="" />
    </settings>
    

    更改配置文件。代码如下:

    <settings>
          <setting name="logImpl" value="LOG4J" />
          <setting name="lazyLoadingEnable" value="true" />
    </settings>
    

    4. 使用 fetchType 属性设置局部加载策略

    使用配置选项 lazyLoadingEnabled 和 aggressiveLazyLoading 设置的是全局加载行为。如果想针对某一个映射来决定是延迟加载还是立即加载,那么可以在 配置中使用 fetchType 属性来决定,属性值 eager 代表立即加载,属性值 lazy 代表延迟加载。

  • 相关阅读:
    HTML
    数据库
    EF增删查改(三)------终极版
    三层的之间的引用
    sql:PostgreSQL
    csharp:SQLite and Access using C# code read data
    sql:Mysql create view,function,procedure
    sql: MySQL and Microsoft SQL Server Stored Procedures IN, OUT using csharp code
    Working C# code for MySql5.5 Stored Procedures IN parameters
    csharp:search and Compare string
  • 原文地址:https://www.cnblogs.com/john1015/p/13959819.html
Copyright © 2020-2023  润新知