Mybatis 常见面试题

mybatis 的工作原理
  • 读取 MyBatis 配置文件:mybatis-config.xml 为 MyBatis 的全局配置文件,配置了 MyBatis 的运行环境等信息,例如数据库连接信息
  • 加载映射文件,映射文件即 SQL 映射文件,该文件中配置了操作数据库的 SQL 语句,需要在
    MyBatis 配置文件 mybatis-config.xml 中加载,mybatis-config.xml 文件可以加载多个映射文
    件,每个文件对应数据库中的一张表
  • 构造会话工厂:通过 MyBatis 的环境等配置信息构建会话工厂 SqlSessionFactory
  • 创建会话对象:由会话工厂创建 SqlSession 对象,该对象中包含了执行 SQL 语句的所有方法
  • Executor 执行器:MyBatis 底层定义了一个 Executor 接口来操作数据库,它将根据 SqlSession 传递的参数动态地生成需要执行的 SQL 语句,同时负责查询缓存的维护
  • MappedStatement 对象:在 Executor 接口的执行方法中有一个 MappedStatement 类型的参
    数,该参数是对映射信息的封装,用于存储要映射的 SQL 语句的 id、参数等信息
  • 输入参数映射:输入参数类型可以是 Map、List 等集合类型,也可以是基本数据类型和 POJO 类型,输入参数映射过程类似于 JDBC 对 preparedStatement 对象设置参数的过程
  • 输出结果映射:输出结果类型可以是 Map、 List 等集合类型,也可以是基本数据类型和 POJO 类型,输出结果映射过程类似于 JDBC 对结果集的解析过程

mybatis都有哪些 Executor 执行器 ?它们之间的区别是什么?
  • Mybatis有三种基本的Executor执行器:SimpleExecutor、ReuseExecutor、BatchExecutor
    • SimpleExecutor:每执行一次 update 或 select,就开启一个 Statement 对象,用完立刻关闭 Statement 对象
    • ReuseExecutor:执行 update 或 select,以 sql 作为 key 查找 Statement 对象,存在就使用,不存在就创建,用完后,不关闭 Statement 对象,而是放置于 Map<String, Statement>内,供下一次使用;简言之,就是重复使用Statement对象
    • BatchExecutor:执行 update ( 没有 select,JDBC 批处理不支持 select ),将所有 sql 都添加到批处理中 addBatch() ,等待统一执行 executeBatch(),它缓存了多个 Statement 对象,每个 Statement 对象都是 addBatch() 完毕后,等待逐一执行 executeBatch() 批处理,与 JDBC 批处理相同

作用范围:Executor 的这些特点,都严格限制在 SqlSession 生命周期范围内


#{} 和 ${} 的区别
  • #{} 是占位符,预编译处理,${} 是拼接符,字符串替换,没有预编译处理
  • mybatis 在处理 #{} 时,#{} 传入参数是以字符串传入,会将 sql 中的 #{} 替换为 ? 号,调用
    PreparedStatement 的 set 方法来赋值
  • #{} 可以有效的防止 sql 注入,提高系统安全性,${} 不能防止 sql 注入
  • #{} 的变量替换是在 DBMS 中,${} 的变量替换是在 DBMS 外

xml 映射文件中,除了常见的 select、insert、updae、delete 标签之外,还有哪些标签 ?
  • 还有很多其他的标签, <resultMap> 、 <parameterMap> 、 <sql> 、 <include> 、 <selectKey>
  • 加上动态 sql 的 9 个标签,trim、where、set、foreach、if、choose、when、otherwise、bind 等,其中 <sql> 为 sql 片段标签,通过 <include> 标签引入 sql 片段, <selectKey> 为不支持自增的主键生成策略标签

Mybatis是如何进行分页的 ?分页插件的原理是什么?
  • 使用 RowBounds 对象进行分页,它是针对 ResultSet 结果集执行的内存分页,而非物理分页
  • 可以在 sql 内直接书写带有物理分页的参数来完成物理分页功能
  • 也可以使用分页插件来完成物理分页
    • 分页插件的基本原理是使用 mybatis 提供的插件接口,实现自定义插件,在插件的拦截方法内拦截
    • 待执行的 sql,然后重写 sql,根据 dialect 方言,添加对应的物理分页语句和物理分页参数
      • 举例:select * from student
      • 拦截 sql 后重写为:select t.* from (select * from student) t limit 0, 10

mybatis 的一级、二级缓存
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

tytler

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

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

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

打赏作者

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

抵扣说明:

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

余额充值