① 读取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方法设置属性值,再继续查询目标方法,就有值了