架构师面试题系列之Mybatis面试专题及答案(36题)

目录


1、什么是 MyBatis?

答:MyBatis 是⼀个可以⾃定义 SQL、存储过程和⾼级映射的持久层框架。

2、讲下 MyBatis 的缓存

答:MyBatis 的缓存分为⼀级缓存和⼆级缓存,⼀级缓存放在 session ⾥⾯,默认
就有,⼆级缓存放在它的命名空间⾥,默认是不打开的,使⽤⼆级缓存属性类需要
实现 Serializable 序列化接⼝(可⽤来保存对象的状态),可在它的映射⽂件中配置cache

3、Mybatis 是如何进行分页的?分页插件的原理是什么?

答:
1)Mybatis 使⽤ RowBounds 对象进⾏分⻚,也可以直接编写 sql 实现分⻚,
也可以使⽤ Mybatis 的分⻚插件。
2)分⻚插件的原理:实现 Mybatis 提供的接⼝,实现⾃定义插件,在插件的
拦截⽅法内拦截待执⾏的 sql,然后重写 sql。
举例:select from student,拦截 sql 后重写为:select t. from (select * from
student)t limit 0,10

4、简述 Mybatis 的插件运行原理,以及如何编写一个插件?

答:
1)Mybatis 仅可以编写针对 ParameterHandler、ResultSetHandler、
StatementHandler、Executor 这 4 种接⼝的插件,Mybatis 通过动态代理,为
需要拦截的接⼝⽣成代理对象以实现接⼝⽅法拦截功能,每当执⾏这 4 种接⼝
对象的⽅法时,就会进⼊拦截⽅法,具体就是 InvocationHandler 的 invoke()⽅
法,当然,只会拦截那些你指定需要拦截的⽅法。
2)实现 Mybatis 的 Interceptor 接⼝并复写 intercept()⽅法,然后在给插件编
写注解,指定要拦截哪⼀个接⼝的哪些⽅法即可,记住,别忘了在配置⽂件中
配置你编写的插件。

5、Mybatis 动态 sql 是做什么的?都有哪些动态 sql?能简述一

下动态 sql 的执行原理不?
答:
1)Mybatis 动态 sql 可以让我们在 Xml 映射⽂件内,以标签的形式编写动态
sql,完成逻辑判断和动态拼接 sql 的功能。
2)Mybatis 提供了 9 种动态 sql 标签:
trim|where|set|foreach|if|choose|when|otherwise|bind。
3)其执⾏原理为,使⽤ OGNL 从 sql 参数对象中计算表达式的值,根据表达
式的值动态拼接 sql,以此来完成动态 sql 的功能。

6、#{}和${}的区别是什么?

答:
1)#{}是预编译处理,${}是字符串替换。
2)Mybatis 在处理#{}时,会将 sql 中的#{}替换为?号,调⽤
PreparedStatement 的 set ⽅法来赋值;
3)Mybatis 在处理{}时,就是把时,就是把{}替换成变量的值。
4)使⽤#{}可以有效的防⽌ SQL 注⼊,提⾼系统安全性。

7、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区

别在哪里?
答:Hibernate 属于全⾃动 ORM 映射⼯具,使⽤ Hibernate 查询关联对象或
者关联集合对象时,可以根据对象关系模型直接获取,所以它是全⾃动的。⽽
Mybatis 在查询关联对象或关联集合对象时,需要⼿动编写 sql 来完成,所
以,称之为半⾃动 ORM 映射⼯具。

8、Mybatis 是否支持延迟加载?如果支持,它的实现原理是什

么?
答:
1)Mybatis 仅⽀持 association 关联对象和 collection 关联集合对象的延迟加
载,association 指的就是⼀对⼀,collection 指的就是⼀对多查询。在 Mybatis
配置⽂件中,可以配置是否启⽤延迟加载 lazyLoadingEnabled=true|false。
2)它的原理是,使⽤ CGLIB 创建⽬标对象的代理对象,当调⽤⽬标⽅法时,
进⼊拦截器⽅法,⽐如调⽤ a.getB().getName(),拦截器 invoke()⽅法发现
a.getB()是 null 值,那么就会单独发送事先保存好的查询关联 B 对象的 sql,
把 B 查询上来,然后调⽤ a.setB(b),于是 a 的对象 b 属性就有值了,接着
完成 a.getB().getName()⽅法的调⽤。这就是延迟加载的基本原理。

9、MyBatis 与 Hibernate 有哪些不同?

答:
1&#x

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

cesske

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

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

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

打赏作者

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

抵扣说明:

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

余额充值