Java 架构师面试题系列之 Mybatis 面试专题(36 题,含详细答案解析

本文详述了Mybatis的Interceptor插件实现、动态SQL的使用及原理,对比了#{ }与${ }的区别,解释了Mybatis为何被称为半自动ORM工具及其与Hibernate的差异。此外,还讨论了延迟加载的实现、Mybatis与其他ORM框架的对比以及其优势,包括接口绑定的实现方式和应用场景。文章最后涵盖了Mybatis的XML映射文件解析、动态Sql的设定和执行批处理的方法。
摘要由CSDN通过智能技术生成

实现 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、#{}和 KaTeX parse error: Expected 'EOF', got '#' at position 18: …的区别是什么?** 答: 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 创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值