MyBatis面试题
MyBatis执行流程
- 读取
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方法的调用
回答:
延迟加载的意思是:就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据
MyBatis支持一对一关联对象和一对多关联集合对象的延迟加载
在MyBatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false
,默认时关闭的
MyBatis的一级、二级缓存用过吗?
本地缓存:基于PerpetualCache
,本质时一个HashMap
一级缓存:作用域时Session级别
二级缓存:作用域时nameSpace和mapper的作用域,不依赖于session
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)