什么是延迟加载?
resultMap可以实现高级映射(使用association、collection实现一对一及一对多映射),association、collection具备延迟加载功能。
需求:
如果查询订单并且关联查询用户信息。如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息。把对用户信息的按需去查询就是延迟加载。
延迟加载:先从单表查询、需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表速度要快。
1、主配置文件:全局配置(在mybatis-config.xml配置)
延迟加载的全局开关,当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置 fetchType 属性来覆盖该项的开关状态
aggressiveLazyLoading:默认false(在 3.4.1 及之前的版本默认值为 true)
当开启时,任何方法的调用都会加载该对象的所有属性。 否则,每个属性会按需加载(参考 lazyLoadTriggerMethods)。
-----------------《一对多》----------------------
1、查询结果结果每个door对应多个order:所以用list<Order>
这里用到查询全部(mybatis查询的规则,看到后面就会明白)
type:结果类型Door全路径,配置全局配置后可以简写Door
<!-- 给每一个对象分配限定名,或者直接扫描包,包内所有对象全部自动用别名-->
<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"/>
<collection>:关联返回值为集合(一对多或者多对多使用)
注意:column:此处规定的是door的主键,用来在order表查找数据
select:关联下一步select的id,若在其他文件中,(全路径名、表.id)
延迟加载:在不执行for循环打即只会执行查询door(一),不会执行查询order(多)