mybatis延迟加载(一对多)

什么是延迟加载?


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

需求:

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

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

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

mybatis延迟加载(一对多)_第1张图片

lazyLoadingEnabled:默认false

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

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

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

mybatis的延迟加载配置规则

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

 1、类设计

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

mybatis延迟加载(一对多)_第2张图片

mybatis延迟加载(一对多)_第3张图片

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

3、Mapper.xml配置

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

mybatis延迟加载(一对多)_第4张图片

4、配置resultmap:

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

   

     

     

      -->

   

property:类属性名

column:数据库字段名

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

属性:

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

  ofType:orders中对象属性

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

mybatis延迟加载(一对多)_第5张图片

5、被关联下一步查询:

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

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

mybatis延迟加载(一对多)_第6张图片

7、配置相关resultmap

mybatis延迟加载(一对多)_第7张图片

8、最后执行方法:

mybatis延迟加载(一对多)_第8张图片

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

mybatis延迟加载(一对多)_第9张图片

mybatis延迟加载(一对多)_第10张图片

 

你可能感兴趣的:(mybatis)