• 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内,供下一次使用;简言之,就是重复使用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 标签之外,还有哪些标签 ?
    • 还有很多其他的标签,
    • 加上动态 sql 的 9 个标签,trim、where、set、foreach、if、choose、when、otherwise、bind 等,其中 为 sql 片段标签,通过 标签引入 sql 片段, 为不支持自增的主键生成策略标签

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

    mybatis 的一级、二级缓存
  • 相关阅读:
    MAC 配置 Maven
    计算机组装与维护实训室解决方案
    SpringCloud微服务实战——搭建企业级开发框架(五十一):微服务安全加固—自定义Gateway拦截器实现防止SQL注入/XSS攻击
    OpenCV第四篇:边缘检测
    LeetCode952三部曲之一:解题思路和初级解法(137ms,超39%)
    4 条件判断和循环
    手机号码骚扰拦截
    RabbitMQ-惰性队列
    TextView文字图片混排并添加点击事件监听,Textview里面的ImageSpan添加点击响应事件
    vue+element-plus完美实现跨境电商商城网站
  • 原文地址:https://blog.csdn.net/qq_41956014/article/details/126695981