Mybatis 面试题 真正的 offer 偏方 Java 基础 Java 高级
一、参考资料
【25年新版Java面试场景题+八股文!真正的offer偏方,跳槽面试你一定用得上!Java面试丨Java场景题丨Java丨Java基础丨Java高级】 https://www.bilibili.com/video/BV1w44y1w7Zh/?p=89\&share_source=copy_web\&vd_source=855891859b2dc554eace9de3f28b4528
二、笔记总结
01、Mybatis 是如何进行分页的
- 直接在 select 语句增加数据库提供的分页关键字
- 使用 Mybatis 提供的 RowBounds 对象,实现内存级别的分页。
- 使用 Mybatis 提供的拦截器,在 SQL 执行前动态拼接分页关键字。
02、Mybatis 中 ${} 和 #{} 的区别是什么
- Mybatis 提供了 # $ 号两种占位符,都是实现动态 SQL 的一种方式,通过这两种方式可以把参数传递到 XML 里面。
号占位符等同于 JDBC 中的 ? 号占位符,# 号占位符可以防止 SQL 注入。
- $ 号占位符相当于直接把原始参数拼接到 SQL 里面,无法防止 SQL 注入的问题。
03、说一说 Mybatis 里面的缓存机制
- Mybatis 设计了二级缓存这样一个机制来提升数据检索效率,避免每一次数据检索都去查询数据库。
- 一级缓存是 SqlSession 级别的缓存,没个用户都需要通过 SqlSession 去查询数据库,为了避免每次都查询数据库,Mybatis 把数据缓存到 SqlSession 的本地缓存中。
- 一级缓存无法做到跨 SqlSession 级别的缓存,因此引入了二级缓存设计,当多个 SqlSession 查询数据的时候,只要有一个用户拿到了数据就会放入二级缓存中,其它的 SqlSession 就可以直接从二级缓存加载数据。
04、Mybatis 何时使用一级缓存,何时使用二级缓存
- 同 03