MyBatis延迟加载
1)延迟加载是什么:
先从单表查询、需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表速度要快。(一个用户存在多个订单,存在外键)。当需要查询用户信息时而不需要使用订单信息时就只查出用户的信息,等需要使用到订单信息再查询出订单信息。
2)使用的场景:
如果查询订单并且关联查询用户信息。如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息。把对用户信息的按需去查询就是延迟加载。
(个人理解说明:对于存在关联关系的表,不使用延迟加载会一次性将其关联对象信息也查出来。所以引入延迟加载,按需加载信息)
3)实现原理:
通过cglib生成目标对象的代理对象,当需要延迟加载时,指向代理对象的拦截器方法。
待补充。