MyBatis执行流程和延迟加载的原理

本文介绍了如何在MyBatis中读取配置、创建会话工厂及执行SQL,重点讲解了一对多关联对象的延迟加载原理,包括CGLIB创建代理对象、拦截器的invoke方法和数据加载过程。
摘要由CSDN通过智能技术生成

① 读取MyBatis配置文件:mybatis-config.xml加载运行环境和映射文件
②) 构造会话工厂qlSessionFactory
③ 会话工厂创建SqlSession对象(包含了执行SQL语句的所有方法)
④ 操作数据库的接口,Executor执行器,同时负责查询缓存的维护
⑤ Executor接口的执行方法中有一个MappedStatement类型的参数,封装了映射信息
⑥ 输入参数映射
⑦ 输出结果映射

延迟加载的原理

1.使用CGLIB创建目标对象的代理对象

2.当调用目标方法user.qetOrderlist0时,进入拦截器invoke方法,发现user.getOrderlist0是nul值,执行sql查询order列表

3.把order查询上来,然后调用user.setOrderList(List<Order>orderist),接着完成user.getOrderlist()方法的调用

面试参考回答:

Mybatis是否支持延迟加载?

延迟加载的意思是:就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据。
Mybatis支持一对一关联对象和一对多关联集合对象的延迟加载
在Mybatis配置文件中,可以配置是否启用延迟加载lazvoadingEnabled=truelfalse,默认是关闭的

延迟加载的底层原理知道吗?

1.使用CGLIB创建目标对象的代理对象
2.当调用目标方法时,进入拦截器invoke方法,发现目标方法是null值,执行sql查询3.获取数据以后,调用set方法设置属性值,再继续查询目标方法,就有值了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java菜鸟、

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值