面试 Java 框架八股文五问五答第五期
作者:程序员小白条,个人博客
相信看了本文后,对你的面试是有一定帮助的!
?点赞?收藏?不迷路!?
1)MyBatis 中 #{} 和 ${} 的区别是什么?
#{}
是预编译的参数,MyBatis 会使用 PreparedStatement 的参数占位符来替换 #{}
,这样可以防止 SQL 注入攻击。${}
是直接拼接参数,不进行预编译。在使用 ${}
时需要注意防范 SQL 注入攻击,因为用户输入可能直接替换其中的内容。
一般来说,推荐使用 #{}
来处理参数,以提高安全性和预编译的效果。
2)MyBatis 是否支持延迟加载?
是的,MyBatis 支持延迟加载。延迟加载是指在需要使用某个属性时再去加载它,而不是在加载对象时就把所有属性都加载出来。MyBatis 提供了两种类型的延迟加载:
- 按需加载(On Demand): 在需要使用属性时,执行额外的 SQL 语句去加载。可以通过配置
fetchType="lazy"
来实现。 - 关联对象延迟加载(Association Lazy Loading): 仅在需要使用关联对象时才加载,通过配置关联对象的
select
属性来实现。
3)说一下 MyBatis 的一级缓存和二级缓存
- 一级缓存(Local Cache): 默认情况下,MyBatis 开启了一级缓存,它是 SqlSession 级别的缓存,即在同一个 SqlSession 中执行相同的查询语句会直接从缓存中获取结果,而不需要再次查询数据库。一级缓存是默认开启的,可以通过在配置文件中配置
<setting name="localCacheScope" value="STATEMENT"/>
来关闭。 - 二级缓存(Global Cache): 二级缓存是在多个 SqlSession 之间共享的缓存,因此可以跨 SqlSession 进行数据共享。开启二级缓存需要在配置文件中配置
<setting name="cacheEnabled" value="true"/>
,并且需要在相应的映射文件中设置 <cache/>
元素。默认情况下,二级缓存是关闭的。
4)MyBatis 有哪些执行器?
MyBatis 有三种执行器(Executor):
- SimpleExecutor: 每执行一次 update 或 select 操作,就开启一个 Statement 对象,用完立刻关闭 Statement 对象。
- ReuseExecutor: 执行 update 或 select 操作时,如果会话没有commit 或 rollback,就会重用之前的 Statement 对象。
- BatchExecutor: 批量执行 Statement 对象,用于批量操作。
在配置文件中可以通过 <setting name="executorType" value=""/>
来指定使用哪种执行器,其中 executorType
的值可以是 SIMPLE
、REUSE
或 BATCH
。
5)MyBatis 和 Hibernate 的区别有哪些?
- 领域模型: Hibernate 更注重对象的领域模型,它通过映射对象和数据库表的关系来进行持久化。而 MyBatis 更注重 SQL 映射,允许开发者直接编写 SQL。
- 性能: MyBatis 的性能通常比 Hibernate 更高,因为开发者可以直接优化 SQL 查询语句,而 Hibernate 的 HQL 查询语句需要转换成 SQL。
- 学习曲线: MyBatis 学习曲线相对较低,尤其对于熟悉 SQL 的开发者。Hibernate 则需要学习较多的概念和配置。
- 灵活性: MyBatis 更加灵活,适合需要对现有 SQL 进行优化的场景。Hibernate 则更适合对象关系映射较为简单的场景。
- 适用场景: MyBatis 更适合需要定制 SQL、对现有数据库表结构有较多了解的场景。Hibernate 更适合对象领域模型较为复杂、数据库表结构与对象模型差异较大的场景。