MyBatis面试题

MyBatis执行流程

image

  • 读取mybatis-config.xml文件
  • 构建会话工厂sqlSessionFactory
  • 创建会话SqlSession
  • Executor执行器
  • MappedStatement对象
  • 访问数据库

完整回答:
1、读取MyBatis配置文件:mybatis-config.xml加载运行环境和映射文件
2、构造会话工厂SqlSessionFactory
3、会话工厂创建SqlSession对象(包含了执行SQL语句的所有方法)
4、操作数据库的接口,Executor执行器,同时负责查询缓存的维护
5、Executor接口的执行方法中有一个MapperedStatement类型的参数,封装了映射信息
6、输入参数映射
7、输出结果映射

Mybatis是否支持延迟加载?

在MyBatis支持延迟加载,但默认没有开启

延迟加载的原理:
1、使用CGLIB创建目标对象的代理对象
2、当调用目标方法user.getOrderList()时,进入拦截器invoke方法,发现user.getOrderList()时null值
执行order列表
3、把order查询上来,然后调用user.setOrderList(List<Order> orderList),接着完user.getOrderlist方法的调用
image

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

MyBatis的一级、二级缓存用过吗?

本地缓存:基于PerpetualCache,本质时一个HashMap
一级缓存:作用域时Session级别
二级缓存:作用域时nameSpace和mapper的作用域,不依赖于session

posted @   自学Java笔记本  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示