• mybatis(三)懒加载


    懒加载的好处:

      所谓懒加载(lazy)就是延时加载,延迟加载。什么时候用懒加载呢,我只能回答要用懒加载的时候就用懒加载。至于为什么要用懒加载呢,就是当我们要访问的数据量过大时,明显用缓存不太合适,
    因为内存容量有限 ,为了减少并发量,减少系统资源的消耗,我们让数据在需要的时候才进行加载,这时我们就用到了懒加载。
    总结为:

    1> 不必将创建对象的代码全部写在viewDidLoad方法中,代码的可读性更强,层次感很强。


    2> 每个属性的getter方法中分别负责各自的实例化处理,代码彼此之间的独立性强,松耦合

    3>只有当真正需要资源时,再去加载,节省了内存资源。

    操作步骤:

    一、在mybatis配置文件中打开启用懒加载

    config.xml:

    <!-- 三、懒加载 -->
        <settings>  
            <!--  打开延迟加载的开关  -->  
            <setting name="lazyLoadingEnabled" value="true" />  
            <!--  将加载改为按需加载  -->  
            <setting name="aggressiveLazyLoading" value="false"/>  
        </settings> 

    二、在映射sql语句的xml中配置运用懒加载

    dept.xml:

        <resultMap type="Dept" id="DeptList2">
            <result column="deptno" property="deptno"/>
            <result column="dname" property="dname"/>
            <result column="loc" property="loc"/>
    <!--        懒加载内容:::-->
    <!--        property:查询数据的实体类型  select:sql语句的地址ofType:语句对应实体。-->
    <!--            column:至关重要,表关联的查询关联字段可能不尽一样,但是以主表字段为纽带,让另一张表的查询字段去用它的值查询,-->
    <!--                该字段错误,主表可以得到数据,懒加载会报空指针异常。-->
            <collection property="emps" 
                select="com.ckx.entityMapper.Emp.selectEmps2"  column="deptno" ofType="Emp">
            </collection>
        </resultMap>
        
        <select id="selectDeptNo" parameterType="int" resultMap="DeptList2">
            SELECT * FROM dept WHERE DEPTNO = #{deptno};
        </select>

    注意:在selectDeptNo中我们至于要知道需要查询的部门的数据,但他的返回值resultMap="DeptList2"是个集合,请注意,并且在该集合里配置了

    职员表的懒加载,在我们需要的术后,懒加载才会帮我们去加载相对部门的职员信息。

    三、运行测试

    DeptTest.java:

    public void selectDeptNo(){
            DeptDao dao = sqlSession.getMapper(DeptDao.class);
            Dept d = dao.selectDeptNo(20);
            System.out.println(d.getDname());
            List<Emp> list = d.getEmps();
            for (Emp emp : list) {
                System.out.println(emp.getEname()+"	"+emp.getSal());
            }
        }

    注意事项:

     
  • 相关阅读:
    制作一个漂亮的表格
    模版语言
    Django 学习
    linux系统服务名称
    CentOS下netstat + awk 查看tcp的网络连接状态
    Python的MySQLdb模块安装
    shellinabox安装
    堡垒机 paramiko 自动登陆代码
    堡垒机 paramiko代码
    Paramiko 模块使用
  • 原文地址:https://www.cnblogs.com/ckxlovejava/p/6081617.html
Copyright © 2020-2023  润新知