Mybatis面试题

简介: Mybatis面试题

mybatis是什么?其优缺点是什么?

mybatis是ORM框架,提供Java Object到数据库Relation操作的映射,同时提供对JDBC的操作的包装和优化,包括连接池的优化、缓存的优化、事务管理等。

通过构建mapper映射接口和xml配置文件,可以很灵活的做好java实体类和jdbc实体间的映射操作;

  • mybatis的架构和原理?

mybatis的架构主要分为三层:

  1. 接口层:主要是向外提供增删改查的接口。
  2. 数据处理层:主要就是sql和参数传入到结果传出的过程,包括的流程有参数映射、SQL解析、SQL执行、结果映射;
  3. 支撑层:主要负责数据库的连接、事务管理、配置加载还有缓存管理等功能。

mybatis的处理流程包括:

  1. 读取配置文件,生成配置项。通过读取mybati-config.xml配置文件和mapper文件,生成配置项MappedStatement;
  2. 构建会话工厂sqlSessionFactory;这个是mybatis根据configuration来生成的;
  3. 通过sqlSessionFactory构建sqlSession,其中sqlSession就对应一个mapper文件。
  4. 通过执行器Executor来执行解析后的sql;其中每个sql会包装成一个mappedStatement;

一文搞懂Mybatis架构与工作原理:

一文搞懂Mybatis架构与工作原理 - 掘金

  • mybatis的缓存机制?

mybatis有二级缓存管理机制;

  1. 一级缓存管理:在Executor查询database之前,会查询本地缓存,由于每个sqlSession有自己的Executor,所以每个Executor有自己的LocalCache,该缓存查询的key值根据statementId、params、rowBound共同决定;
  2. 二级缓存管理:由于一级缓存知识针对单个sqlSession,针对不同的sqlSession可以配置二级缓存对象,实现多个sqlSession间的缓存共享,可以自己实现cache类也可以引入第三方的缓存服务;
  • mybatis中xml映射文件#{}和${}的区别是什么?
  1. #{}的是在数据库预编译阶段处理,调用PreparedStatement的set方法将#{}占位符替换成?
  2. ${}的处理只是用值替换掉该占位符。使用${}可能有sql注入的风险。

总结:在使用order by和group by语句时,必须要使用${}

  • mybatis中数据库字段名和实体属性名如何映射?

Mybatis查询数据库的结果会保存在ResultSet中,然后将该对象映射到Java对象中,其映射的方式包括以下几种:

  1. 通过数据库字段名和实体属性名映射。这个是默认的映射方式。
  2. 通过设置别名。如果sql语句中设置了别名,会优先使用数据库别名和Java实体属性名进行映射。
  3. 通过ResultMap来设置据库字段名和实体属性名的映射。

  <resultMap id="BaseResultMap" type="com.yangnk.mysqldemo.entity.User1" >

    <id column="id" property="id" jdbcType="INTEGER" />

    <result column="user_name" property="userName" jdbcType="VARCHAR" />

    <result column="password" property="password" jdbcType="VARCHAR" />

    <result column="sex" property="sex" jdbcType="VARCHAR" />

  </resultMap>

  1. 可以自定义TypeHandler,如果以上配置的映射方式无法满足需求,可以自定义TypeHandler来实现数据库字段名和实体属性名之间的映射。
  • mybatis如何实现分页?
  1. 可以在sql中进行limit限制,进行物理分页,也是比较推荐的,一般分页插件是通过这种方式来实现的,通过mybatis提供的插件机制,通过filter拦截sql,对其进行改造,再执行;
  2. 另一种是mybatis自带的分页特性,他主要是通过内存分页来实现的,就是再查询出所有结果到内存中后,再进行内存分页。这个是通过RowBound来实现的,其中指定了offset和limit参数,在全部查询出数据后再进行内存分页。
  • mybatis实现动态SQL的原理?

动态SQL是指可以根据不同的条件生成不同的SQL,这个主要可以通过标签来实现,包括常见的if标签、foreach标签、when标签等。

  • mybatis的Mapper接口为什么没有实现类还能调用?

通过JDK动态代理的方式实现了对目标对象的操作,其实是调用MapperProxy的invoke方法。

  • Mybatis和Hibernate的区别?

Mybatis和Hibernate都是经典的ORM框架,便于Java对象直接操作数据库,他们都能够支持事务管理和缓存管理等特性。

他们的主要区别如下:

  1. Mybatis是半自动的框架,Hibernate是全自动的框架。Mybatis的sql语句需要自己编写,可以编写更复杂和灵活的sql;Hibernate只要配置好数据库关系和Java DO的关系,之后的增删改查操作都能通过Hibernate自动完成。
  2. Mybatis更加灵活和高效,由于其能够自定义sql,所以适应的场景更多;Hibernate相对来说更容易入手,针对只需要简单增删改查的场景是比较方便的。


目录
相关文章
|
6月前
|
缓存 Java 数据库连接
Mybatis缓存相关面试题有多卷
使用 MyBatis 缓存机制需要注意以下几点: 对于频繁更新和变动的数据,不适合使用缓存。 对于数据的一致性要求比较高的场景,不适合使用缓存。 如果配置了二级缓存,需要确保缓存的数据不会影响到其他业务模块的数据。 在使用缓存时,需要注意缓存的命中率和缓存的过期策略,避免缓存过期导致查询性能下降。
104 0
|
6月前
|
Java 关系型数据库 数据库连接
BATJ高频面试249道题:微服务+多线程+分布式+MyBatis +Spring
本文收集整理了各大厂常见面试题N道,你想要的这里都有内容涵盖:Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、Redis、MySQL、Spring、Spring Boot、Spring Cloud、RabbitMQ、Kafka、Linux 等技术栈,希望大家都能找到适合自己的公司,开开心心的撸代码。
|
5月前
|
SQL 缓存 Java
MyBatis最经典的20道面试题,你都会了吗?
MyBatis最经典的20道面试题,你都会了吗?
63 0
|
6月前
|
SQL 缓存 Java
Mybatis面试题
Mybatis面试题
|
4月前
|
SQL Java 数据库连接
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
70 0
|
6月前
|
存储 缓存 Java
什么!?实战项目竟然撞到阿里面试的原题!???关于MyBatis Plus的缓存机制
什么!?实战项目竟然撞到阿里面试的原题!???关于MyBatis Plus的缓存机制
|
6月前
|
SQL Java 数据库连接
MyBatis常见面试题总结2
MyBatis常见面试题总结
52 0
|
6月前
|
SQL Java 数据库连接
MyBatis常见面试题总结1
MyBatis常见面试题总结
62 0
|
6月前
|
SQL Java 数据库连接
答案很详细的MyBatis面试题(含示例代码)
MyBatis是一种优秀的持久层框架,它是一个轻量级的、优化的、功能强大的Java持久层框架,它的设计理念是贴近SQL、便于使用、高效并且功能丰富。通过MyBatis的使用,开发者能够更加专注于业务逻辑的实现,而不用过多关注底层的数据库操作。MyBatis通过XML或注解的方式配置SQL映射文件,并将Java的POJO(Plain Old Java Object,普通的Java对象)与数据库中的记录进行映射,使得开发人员能够以面向对象的方式来操作数据库,同时兼顾了SQL的灵活性和效率。灵活的SQL映射。
282 0
|
6月前
|
SQL Java 数据库连接
MyBatis常见面试题和答案(2020最新版)
MyBatis常见面试题和答案(2020最新版)
280 0