mybatis延迟加载(一对多)

什么是延迟加载?


resultMap可以实现高级映射(使用association、collection实现一对一及一对多映射),association、collection具备延迟加载功能。

需求:

如果查询订单并且关联查询用户信息。如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息。把对用户信息的按需去查询就是延迟加载。

延迟加载:先从单表查询、需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表速度要快。

1、主配置文件:全局配置(在mybatis-config.xml配置)

lazyLoadingEnabled:默认false

延迟加载的全局开关,当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置 fetchType 属性来覆盖该项的开关状态

aggressiveLazyLoading:默认false(在 3.4.1 及之前的版本默认值为 true)

当开启时,任何方法的调用都会加载该对象的所有属性。 否则,每个属性会按需加载(参考 lazyLoadTriggerMethods)。

mybatis的延迟加载配置规则

-----------------《一对多》----------------------

 1、类设计

1、查询结果结果每个door对应多个order:所以用list<Order>

2、接口设计:返回的是door集合

3、Mapper.xml配置

这里用到查询全部(mybatis查询的规则,看到后面就会明白)

4、配置resultmap:

type:结果类型Door全路径,配置全局配置后可以简写Door

<typeAliases>

    <!--  给每一个对象分配限定名,或者直接扫描包,包内所有对象全部自动用别名-->

      <typeAlias type="com.tedu.pojo.Door" alias="Door"/>

      <typeAlias type="com.tedu.pojo.Order" alias="Order"/>

      <typeAlias type="com.tedu.pojo.Emp" alias="Emp"/>-->

    <package name="com.tedu.pojo"/>

</typeAliases>

property:类属性名

column:数据库字段名

<collection>:关联返回值为集合(一对多或者多对多使用)

属性:

注意:column:此处规定的是door的主键,用来在order表查找数据

  ofType:orders中对象属性

  select:关联下一步select的id,若在其他文件中,(全路径名、表.id)

5、被关联下一步查询:

接口配置:传入的是上面的door主键

6、mapper.xml配置:通过id查全表

7、配置相关resultmap

8、最后执行方法:

延迟加载:在不执行for循环打即只会执行查询door(一),不会执行查询order(多)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值