Mybatis面试题

  • 1、什么是Mybatis?
  • 2、介绍下Mybatis的工作原理?
  • 3、Mybatis中缓存的理解?
  • 6、#和$的区别?
  • 7、如何解决属性名和字段名不一致的情况?
  • 8、如何获取自动增长的主键?
  • 9、Mybatis中的设计模式?
  • 10、Mybatis映射文件和配置文件的了解?
    • 10.1 Mybatis映射文件中有哪些标签?
    • 10.2 Mybatis核心配置文件中有哪些标签?
  • 11、Mybatis怎么实现分页的?
  • 12、Mybatis中的执行器?
  • 13、Mybatis中的Mapper接口和Mapper映射文件的一致性问题?
  • 14、DefaultSqlSession的线程安全?
    • 14.2 Spring整合Mybatis是如何来解决数据安全问题的?

1、什么是Mybatis?

Mybatis是一个半ORM框架(对象关系映射),专注于SQL语句,不用关心JDBC操作的其他流程,提高了对数据库的开发效率。

Hibemate是全ORM框架、基于JDBC封装的框架


2、介绍下Mybatis的工作原理?

(1)介绍Mybatis的基本情况:ORM

(2)原理:

  • Mybatis框架的初始化操作
  • 处理SQL请求的流程

系统启动的时候会加载解析全局配置文件和对应的映射文件,加载解析的相关信息存储在Configuration对象,Configuration对象会跟SqlSessionFactory对象绑定,当用户请求到来的时候,会从SqlSessionFactory对象中获取SqlSession。

SqlSessionFactory–>SqlSession


3、Mybatis中缓存的理解?

  • 缓存的作用: 降低数据源的访问频率,从而提高数据源的处理能力,提高服务器的响应速度。
  • Mybatis中的缓存设计:
    • Mybatis中的缓存的架构设计
    • Mybatis中的一级缓存和二级缓存

# 4、Mybatis中如何实现缓存的扩展?


# 5、Mybatis和Hibernate的区别?


6、#和$的区别?

  • Mybatis中获取参数值的两种方式:#{}${}
    -#{}(使用较多的一种方式)
    • #{}的本质是占位符赋值;
    • #{} 是预编译处理,在Mybatis处理#{}的时候会替换为"?“,然后调用PrepareStatement的set方法来对”?"进行赋值。
  • ${}
    - ${}的本质是字符串拼接;
    • ${} 是Mybatis处理的时候就会直接替换,会有SQL注入的风险。

7、如何解决属性名和字段名不一致的情况?

  • 方式一:为查询的字段设置别名,和属性名保持一致;
  • 方式二:当字段符合MySQL的要求使用_,而属性符合java的要求使用驼峰。此时可以在mybatis的核心配置文件中设置一个全局配置,可以自动的将下划线映射为驼峰;
  • 方式三:通过resultMap来设置字段和属性的映射关系;

8、如何获取自动增长的主键?

在使用insert标签的时候,设置标签属性useGeneratedKeys=truekeyProperty=“id”,获取到自动增长的主键。

    <!--
        useGeneratedKeys:表示当前添加功能使用自增的主键;
        keyProperty:将添加的数据自增的主键赋值给实体类型的参数的属性赋值;
    -->
    <insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
        insert into t_user values (null,#{username},#{password},#{age},#{gender},#{email})
    </insert>

9、Mybatis中的设计模式?

  • 缓存模块:装饰器模式
  • 日志模块:适配器模式
  • SqlSessionFactory:工厂模式
  • Mapper接口:代理模式
  • SqlSessionFactoryBuiler:建造者模式

10、Mybatis映射文件和配置文件的了解?

10.1 Mybatis映射文件中有哪些标签?

  • 处理CRUD操作的标签:
    selectdeleteupdateinsert

  • sql:SQL代码片段

  • cache:开启缓存需要在映射文件中设置cache标签

  • cache-ref:

  • resultMap:自定义映射关系

10.2 Mybatis核心配置文件中有哪些标签?

  • properties:引入properties配置文件,例如配置数据库的jdbc.properties

  • settings:可以设置自动将下划线映射为驼峰、开启延迟加载、按需加载等。

  • typeAliases:类型别名。

  • environments :配置链接数据库的环境

  • mappers:引入MyBatis的映射文件。


11、Mybatis怎么实现分页的?

逻辑分页和物理分页两种

  • 逻辑分页

    • 数据库中有10000条数据,会给服务器10000条数据,客户端需要5条数据去分页,则服务器给客户端5条数据实现分页,这是一种虚拟的分页。
    • 不是真正的分页,RowBounds来进行分页。
  • 物理分页

    • 数据库中有10000条数据,会给服务器10000条数据,客户端需要5条数据去分页,服务器会给客户端10000条数据,然后分页。

    • 我们通过拦截器来实现分页的,

      select * from xxx —> select * from (select * from xxx) t limit 0.10


12、Mybatis中的执行器?

执行器是什么?

SimpleExector:简单的执行器。每次执行操作都会开启一个新的Statement对象,用完就会like关闭。

ReuseExector:复用的执行器。实现了对Statement对象的复用。

BatchExector:可执行批处理任务的执行器。

所有的执行器都必须是在SqlSession的生命周期之内。


13、Mybatis中的Mapper接口和Mapper映射文件的一致性问题?

  • Mapper接口类的名称和Mapper映射文件的名称要保持一致;
  • namespace的名称要和接口类的全类路径要保持一致;
  • Mapper接口类中的方法名要和Mapper映射文件中Sql语句的id属性保持一致;
  • Mapper接口类中方法的返回类型要和Mapper映射文件中SQL语句的返回类型一致;

14、DefaultSqlSession的线程安全?

DefaultSqlSession是线程不安全的。

## 14.1 DefaultSqlSession是什么?

14.2 Spring整合Mybatis是如何来解决数据安全问题的?

我们在工作中都不会单独的使用DefaultSqlSession,而是整合了Spring框架来使用Mybatis。

  • 不安全的原因
    线程不安全的原因是因为多个线程操作同一个对象,而这个对象被定义为了一个成员变量。

  • 解决的方案
    就是把这个成员变量变成一个局部变量,让多个线程不能操作就可以了。

  • Spring整合Mybatis是如何来解决数据安全问题的
    创建了一个SqlSessionTemplate模板对象,定义了数据库操作的相关的方法,本质上是通过代理对象获取了DefaultSqlSession对象来执行的,而且把DefaultSqlSession对象声明在了局部变量当中,从而解决了线程不安全的问题。

更多推荐

【Mybatis】Mybatis面试题