Mybatis核心知识点整理,常见面试题总结必备!

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: Mybatis核心知识点整理,常见面试题总结必备!

Mybatis核心知识点整理,面试必备!

一、mybatis基础面试题

1、Mybatis框架是什么?

Mybatsi框架是一个数据库持久层的框架,用于对数据库的访问和操作。即Mybatis用于封装JDBC解决Dao的通用问题

2、什么是ORM思想?

对象关系映射,通过面向对象的思想完成对数据库的操作,具体映射如下:


image.png

3、原始JDBC开发存在什么问题?

1. 不能自动完成数据库表与实体对象的映射,产生大量冗余代码
2、没有连接池和缓存,运行效率低
3、JDBC查询关系比较繁琐

4、Mybatis框架有哪些优点?

1.Mybatis自动将数据封装成实体
2.Mybatis提供缓存池,运行效率高
3.Mybtais提供级联查询
4.Mybatis使用XML对SQL语句进行操作,便于后续的维护

5、Mybatis的实现原理是什么?

mapper.xml实现dao层的接口,接口中的实现方法使用
<insert></insert>,添加
<select></select>,选择
<delete></delete>,删除
<update></update>>更新

6、如何搭建Mybatis的运行环境?

1.引入jar包
  (1)核心jar包:MyBatis-3.2.2.jar
  (2)第三方依赖:log4-1.2.17.jar
  (3)数据库的驱动jar包
3.引入相关配置
  (1)核心配置文件 mybatis-config.xml
   (2)接口的实现使用XxxDaoMapper.xml
   (3)做日志输出的配置文件log4j-1.2.17.jar
4.初始化配置
  <configuartion>
   <!--配置mybatis的多个配置文件,default默认配置文件,必须同运行环境的id相同-->
   <environment id="mysql">
    <!--配置事务管理策略,type类型,其中JDBC代表使用JDBC中的事务-->
     <transactionManager type="JDBC"></transactionManager>
     <!---数据库中的连接池,type类型 ,POOLED代表使用mybatis自带的连接池-->
     <dataSource type="POOLED">
       <property name="driver" value="com.tjcu.cj.jdbc.driver"> 
       <property name="url" value="省略">
       <property name="username" value="用户名"> 
       <property name="password" value="密码">
      </dataSource>
   </environment>
   <!--注册映射文件-->
   <mappers>
   <mapper resource="com/tjcu/dao/XxxDaoMapper.xml"></mapper>
   </mappers>
  </configuration>

7、Mybatis的核心API有哪些?简述其作用?

1.Resouce 读取Mybatis的相关配置文件
2.sqlSessionFactoryBuilder:用于创建sqlSessionBuilder
3.sqlSessionFactory:用户创建(打开)sqlSession
4.sqlSession:
        (1)控制事务 sqlSession.commit(); sqlSession.rollback();
        (2)结合Mapper文件创建Dao接口的实现类
        (3)在sqlSession封装了JDBC的connection接口,和Connection一一对应
        (2)关闭连接SQLSession.close();
*注意:
  1.sqlSessionFactory是重量级组件,线程安全,只创建一个sqlSessionFactory
  2.增删改必须控制实现,查询不能控制事务,因为Mybatis的基于namespace的二级缓存的缓存池,释放缓存主要标志就是增删改!

8、采用Mybatis开发Dao的步骤有哪些?

1.建数据库表(t_user)
2.创建实体类(例如User)
3.创建Userdao的接口(查询所有的方法)
4.Mybatis中的Mapper.xml文件实现UserDao的接口
    <mapper namespace="com.tjcu.dao.UserDao">
       <select id="selectAll" resultType="com.tjcu.entity.User">
        select * from t_user;
       </select>
    </mapper>
5.在mybatis-config.xml核心配置中注册mapper文件
 <mapper resource="com/tjcu/dao/UserDaoMapper.xml"></mapper>

9、Mybatis如何实现表单的增删改查?

1.添加一条数据
  注意:生成主键策略还可以使用UUID的方式
  <insert id="insertUser">
    insert into t_user(id,username,password) value(#{id},#{username},#{password});
  </insert>
2.更新一条数据
  <update>
    update t_user 
    <set>
      <if test="username!=null">
        username=#{username},
      </if>
      <if test="password!=null">
        passsword=#{password}
      </if>
    </set>
  </update>
3.删除一个数据
<delete id="deleteById">
 delete from t_user where id=#{id}
</delete>
4.查询数据
 <select id="selectAll" resultType="com.tjcu.entity.User">
        select * from t_user;
 </select>

10、Mybatis如何实现多个参数的接口方法(参数绑定)?

通过参数绑定,在UserDao的接口进行参数绑定
 public User selectByUsernameAndUssername(@oaram("username") String username,@param("password")String password);

11、为什么要封装Mybatis工具类?

减少不必要的冗余,提高代码的可维护性

12、Struts2和Mybatis整合的步骤是什么?

1.引入相关jar包
  (1)struts核心jar包及第三方依赖jar包
   (2)Mybatis核心jar包,数据库的驱动jar包,log4.jar日志jar包
2.引入相关的配置文件
  (1)struts首先在web.xml初始化配置中写Struts2.xml的核心过滤器,引入struts.xml核心配置文件
  (2)Mybatis:mybatis-config.xml核心配置文件,XxxDaoMapper.xml配置文件
  (3)jsbc.properties配置文件
  (4)log4.properties日志配置文件

二、Mybatis进阶面试题

1、类型别名的好处及使用?

1.好处:  减少配置的冗余(对多次使用类型全名的位置进行简化书写)
2.使用:
   # 在mybatis-config.xml中定义别名:
   <typeAliases>
      //type里面写实体类的目标位置
     <typeAlias type="com.tjcu.entity.user"><typeAlias>
   <typeAliases>
   # 在mapper文件中使用别名:
   <select id="selectAll" resultType="user">
   </select>

2、使用别名后采用Mybatis开发Dao的实现步骤?

1.建表
2.开发相对应的实体类
3.实体类型别名的注册
4. Dao接口的提取
5. 使用XxxDaoMapper.xml实现Dao接口
6. Mapper文件的注册

3、如何把提取mybatis-config.xml中数据库相关的参数?

1、把数据库连接相关的参数写在小配置文件中(jdbc.properties);
   mysql版本:**jdbc.properties放到src下** 
    driver=com.mysql.cj.jdbc.Driver
    url=jdbc:mysql://localhost:3306/db1?useSSL=false&serverTimezone=UTC
    username=root
    password=root
2、在mybatis-config.xml中引入小配置文件
   <properties resource="jdbc.properties"/>
3、使用${key}的形式替换原有的mybatis-config.xml配置文件的内容 

4、ResultMapper的好处?

当查询的结果与实体类不匹配时(数据库的字段和实体类的属性不匹配),需要ResultMap进行处理

image.png

5、如何使用ResultMapper?

  <!--结果映射 id:唯一标识 type:要映射的实体类名 全限定名,可以书写别名-->
    <resultMap id="UserResultMap" type="user">
        <!--主键映射比较特殊 column:数据库列 property:实体类-->
        <id column="id" property="id1"></id>
        <result column="username" property="username1"></result>
        <result column="password" property="password1"></result>
        <result column="age" property="age1"></result>
        <result column="birthday" property="birthday1"></result>
    </resultMap>

注意:针对单表的查询操作,可以使用取别名的方式简化开发,Result使用在多表查询操作中


6、Mybatis处理多表查询问题是什么?

1. 表如何体现关系:通过外键
2. 实体类如何维护关系:通过属性
3. mapper文件如何实现dao:需要通过ResultMap映射一次

7、“一”的一方在mapper文件如何维护?

在mapper文件中使用标签,来维护“一”的一方的关系



<resultMap id="empResultMap" type="emp">
        <result column="id " property="id"></result>
        <result column=" anme" property="name"></result>
        <result column="salary " property="salary"></result>
        <association javaType="Dep" property="dep">
            <id column="id" property="id"></id>
            <result column="name" property="name"></result>
            <result column="address" property="address"></result>
        </association>
    </resultMap>
    <!--
   sql片段
   减少Sql语句的冗余,简化开发
    -->
    <sql id="selectEmp_Dep">
        select e.id      as emp_id,
               e.name    as emp_name,
               e.salary  as emp_salary,
               d.id      as dep_id,
               d.name    as dep_name,
               d.address as dep_address
    </sql>
    <!--引用SQL片段-->
    <select id="selectEmpById" resultMap="empResultMap">
        <include refid="selectEmp_Dep"/>
        from emp e
        inner join dep d
        on e.id = d.id
        where e.id = #{id};
    </select>

8、“多”的一方在mapper文件如何维护关系?

多的一方在mapper文件中使用Collection标签进行维护


<mapper namespace="com.tjcu.dao.DepDao">
    <resultMap id="depResultMap" type="dep">
        <id column="id" property="id"></id>
        <result column="name" property="name"></result>
        <result column="address" property="address"></result>
        <collection ofType="Emp" property="emp">
        <result column="id " property="id"></result>
        <result column=" anme" property="name"></result>
        <result column="salary " property="salary"></result>
        </collection>
    </resultMap>
<!--
dep实体类: 
  id; name;address; emp;
emp实体类:
 id;name;salary;dep;
-->
    <select id="selectDepById" resultMap="depResultMap">
        select d.id,d.name,d.address,e.id,e.name,e.salary
        from dep d
                 inner join emp e
                          on d.id = e.id
        where  d.id=#{id};
    </select>
</mapper>

9,“多对多”的关系如何处理?

使用第三张表(中间表)维护多对多关系表的处理
实体的双方都加对方的集合类型属性

10、常见的动态Sql语句有哪些及作用?

sql动态片段:在mapper文件中如果需要书写多个相同的代码片段,对重复的一段sql进行提取,减少冗余
         如:<sql> select * from </sql>
foreach:批量删除,批量查询操作
where:动态生成where查询语句
set:标签,动态修改,去除结尾不相关的,
trim:忽略sql语句末尾多余的关键字或者字符

11、foreach标签的作用是什么?

SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL。
1. 针对(DML)操作,实现批处理
2、针对select操作,处理查询的条件是零散的数据

12、jdbcType的作用是什么?

允许null值为指定列的值(主要用在修改,添加)
使用MyBatis框架做更新操作时,在该字段需要更新的内容为空时,就会出现1111错误,
  也就是无效的列类型,这个时候你就要使用jdbcType。
应用场景就是:
当执行mapping文件的时候,有个映射的参数为空,那么无法确定他的类型,这个时候就需要jdbcType来确定类型。


image.png

13、$和#的区别是什么?

1、 在底层实现不同:$底层采用字符串拼接技术生成动态sql,而#使用?赋值形式动态sql
2、 $存在sql注入风险,#防止sql注入
3、 $ 可以动态拼接sql语句关键字,字段,值,而#只能替换值

14、缓存的好处是什么?

把第一次查询的结果缓存到内存里,之后相同的查询可以直接在缓存中取到,减少与数据库的通信次数,提高查询效率

15、使用缓存的步骤?

1. 开启全局缓存:
  在mybatis-config.xml中配置
<!--开启全局缓存-->
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
2.实现序列化接口
3.配置需要使用缓存的数据:指定在那个mapper文件的查询结果需要缓存,添加<cache></cache>标签

注意:在业务层中,增删改必须添加事务,查询不能添加事务,这样执行增删改之后,自动释放缓存


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
SQL 分布式计算 监控
Sqoop数据迁移工具使用与优化技巧:面试经验与必备知识点解析
【4月更文挑战第9天】本文深入解析Sqoop的使用、优化及面试策略。内容涵盖Sqoop基础,包括安装配置、命令行操作、与Hadoop生态集成和连接器配置。讨论数据迁移优化技巧,如数据切分、压缩编码、转换过滤及性能监控。此外,还涉及面试中对Sqoop与其他ETL工具的对比、实际项目挑战及未来发展趋势的讨论。通过代码示例展示了从MySQL到HDFS的数据迁移。本文旨在帮助读者在面试中展现Sqoop技术实力。
21 2
|
6天前
|
监控 负载均衡 Cloud Native
ZooKeeper分布式协调服务详解:面试经验与必备知识点解析
【4月更文挑战第9天】本文深入剖析ZooKeeper分布式协调服务原理,涵盖核心概念如Server、Client、ZNode、ACL、Watcher,以及ZAB协议在一致性、会话管理、Leader选举中的作用。讨论ZooKeeper数据模型、操作、会话管理、集群部署与管理、性能调优和监控。同时,文章探讨了ZooKeeper在分布式锁、队列、服务注册与发现等场景的应用,并在面试方面分析了与其它服务的区别、实战挑战及解决方案。附带Java客户端实现分布式锁的代码示例,助力提升面试表现。
26 2
|
6天前
|
数据采集 消息中间件 监控
Flume数据采集系统设计与配置实战:面试经验与必备知识点解析
【4月更文挑战第9天】本文深入探讨Apache Flume的数据采集系统设计,涵盖Flume Agent、Source、Channel、Sink的核心概念及其配置实战。通过实例展示了文件日志收集、网络数据接收、命令行实时数据捕获等场景。此外,还讨论了Flume与同类工具的对比、实际项目挑战及解决方案,以及未来发展趋势。提供配置示例帮助理解Flume在数据集成、日志收集中的应用,为面试准备提供扎实的理论与实践支持。
21 1
|
8天前
|
SQL 缓存 Java
Mybatis面试题
Mybatis面试题
|
1月前
|
消息中间件 NoSQL 网络协议
Java面试知识点复习​_kaic
Java面试知识点复习​_kaic
|
6天前
|
分布式计算 资源调度 监控
Hadoop生态系统深度剖析:面试经验与必备知识点解析
本文深入探讨了Hadoop生态系统的面试重点,涵盖Hadoop架构、HDFS、YARN和MapReduce。了解Hadoop的主从架构、HDFS的读写流程及高级特性,YARN的资源管理与调度,以及MapReduce编程模型。通过代码示例,如HDFS文件操作和WordCount程序,帮助读者巩固理解。此外,文章强调在面试中应结合个人经验、行业动态和技术进展展示技术实力。
13 0
|
15天前
|
SQL Java 数据库连接
MyBatis常见面试题总结2
MyBatis常见面试题总结
16 0
|
15天前
|
SQL Java 数据库连接
MyBatis常见面试题总结1
MyBatis常见面试题总结
23 0
|
18天前
|
SQL Java 数据库连接
答案很详细的MyBatis面试题(含示例代码)
MyBatis是一种优秀的持久层框架,它是一个轻量级的、优化的、功能强大的Java持久层框架,它的设计理念是贴近SQL、便于使用、高效并且功能丰富。通过MyBatis的使用,开发者能够更加专注于业务逻辑的实现,而不用过多关注底层的数据库操作。MyBatis通过XML或注解的方式配置SQL映射文件,并将Java的POJO(Plain Old Java Object,普通的Java对象)与数据库中的记录进行映射,使得开发人员能够以面向对象的方式来操作数据库,同时兼顾了SQL的灵活性和效率。灵活的SQL映射。
105 0
|
1月前
|
存储 缓存 Java
什么!?实战项目竟然撞到阿里面试的原题!???关于MyBatis Plus的缓存机制
什么!?实战项目竟然撞到阿里面试的原题!???关于MyBatis Plus的缓存机制