Java面试题【必知必会】Mybatis常见面试题(2024)

近期一直在准备面试,所以为了巩固知识,也为了梳理,整理了一些java的基础面试题!同时也希望各位英雄和女侠能够补充!不胜荣幸!!!

名称 地址
Java面试题【必知必会】基础(2024) Go-Go-Go
Java面试题【必知必会】常见基础题(2024) Go-Go-Go
Java面试题【必知必会】MySQL常见面试题(2024) Go-Go-Go
Java面试题【必知必会】Spring常见面试题(2024) Go-Go-Go
Java面试题【必知必会】Mybatis常见面试题(2024) Go-Go-Go
Java面试题【必知必会】SpringMVC常见面试题(2024) Go-Go-Go
Java面试题【必知必会】SpringBoot常见面试题(2024) Go-Go-Go
Java面试题【必知必会】SpringCloud常见面试题(2024) Go-Go-Go
Java面试题【必知必会】Redis常见面试题(2024) Go-Go-Go
Java面试题【必知必会】Linux常用命令面试题(2024) Go-Go-Go

1.MyBatis是什么?他的优缺点?

  1. MyBatis 是一款优秀的持久层框架,一个半 ORM(对象关系映射)框架,它支持定制化 SQL、存储过程以及高级映射
  2. 优点:
  • 基于SQL语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响,SQL写在XML里,解除sql与程序代码的耦合,便于统一管理;提供XML标签,支持编写动态SQL语句,并可重用
  • 与JDBC相比,减少了50%以上的代码量,消除了JDBC大量冗余的代码,不需要手动开关连接
  • 很好的与各种数据库兼容
  • 提供映射标签,支持对象与数据库的ORM字段关系映射;提供对象关系映射标签,支持对象关系组件维护
  1. 缺点:
  • SQL语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL语句的功底有一定要求
  • SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库

2.JDBC编程有哪些不足之处,MyBatis是如何解决这些问题的?

  1. 数据库链接创建、释放频繁造成系统资源浪费从而影响系统性能,如果使用数据库连接池可解决此问题
  2. Sql语句写在代码中造成代码不易维护,实际应用sql变化的可能较大,sql变动需要改变java代码
  3. 向sql语句传参数麻烦,因为sql语句的where条件不一定,可能多也可能少,占位符需要和参数一一对应
  4. 对结果集解析麻烦,sql变化导致解析代码变化,且解析前需要遍历,如果能将数据库记录封装成pojo对象解析比较方便

3.MyBatis编程步骤是什么样的?

  1. 创建数据库表和实体类:

首先,在数据库中创建对应的表,并创建与表字段对应的Java实体类,通常使用POJO(Plain Old Java Object)来表示实体类。

  1. 配置MyBatis的数据源:

在Spring中,可以通过配置数据源(DataSource)来连接数据库。在MyBatis中,数据源通常配置在XML或Java配置类中。

  1. 编写Mapper映射文件:

在MyBatis中,需要编写Mapper映射文件(通常以.xml为后缀),用于定义SQL语句和映射关系。Mapper映射文件中定义了SQL语句的ID、参数类型、返回类型以及SQL语句本身。

  1. 创建Mapper接口:

为每个Mapper映射文件创建一个对应的Mapper接口,用于在Java代码中调用SQL语句。

  1. 配置MyBatis的SqlSessionFactory和SqlSessionTemplate:

在Spring中,需要配置MyBatis的SqlSessionFactory和SqlSessionTemplate,用于创建SqlSession实例和执行SQL语句。

  1. 执行SQL语句:

在Java代码中,通过调用Mapper接口中定义的方法来执行SQL语句。MyBatis会根据Mapper映射文件中的配置,将SQL语句转换为PreparedStatement,并执行数据库操作。

  1. 处理结果:

执行SQL语句后,可以通过MyBatis提供的结果映射功能,将查询结果映射为Java对象或集合,并在Java代码中进行进一步处理。

  1. 事务管理(可选):

如果需要进行事务管理,可以在MyBatis中配置事务管理器,并在需要事务的方法上添加@Transactional注解。

PS:总体来说,MyBatis编程的关键是配置Mapper映射文件,定义SQL语句和映射关系,并创建Mapper接口用于调用SQL语句。Spring提供了整合MyBatis的支持,使得配置和使用MyBatis更加便捷。同时,MyBatis还提供了丰富的功能,如动态SQL、结果映射、插件扩展等,可以满足复杂的数据库操作需求。

4.请说说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 对结果集的解析过程

5.什么是预编译?为什么要使用预编译?

预编译(Prepared Statement)是数据库操作中的一种技术,它是一种在执行SQL语句之前,先将SQL语句发送到数据库进行编译并生成执行计划,然后再将参数传递给编译后的语句执行的方式。

在使用预编译的过程中,数据库会对SQL语句进行编译,并生成执行计划,然后将编译后的执行计划缓存起来,当下次有相同的SQL语句需要执行时,数据库可以直接使用缓存中的执行计划,只需替换参数即可,而无需重新编译整个SQL语句。这样可以提高数据库操作的执行效率和性能。

使用预编译的好处包括:

  1. 性能提升:由于SQL语句已经预编译并生成执行计划,当多次执行相同的SQL语句时,数据库可以直接使用缓存的执行计划,减少了SQL解析和优化的开销,提高了数据库操作的执行效率。

  2. 安全性:预编译可以防止SQL注入攻击,因为预编译的SQL语句将参数作为占位符处理,而不是将参数直接拼接到SQL语句中,有效避免了SQL注入的风险。

  3. 可读性:预编译的SQL语句将参数作为占位符,使得SQL语句更加清晰易读,易于维护。

  4. 减少数据库压力:通过预编译和缓存执行计划,可以减少数据库解析和优化SQL语句的次数,从而减轻了数据库的负担,提高了数据库的吞吐量。

PS:总体来说,预编译是一种优化数据库操作的方式,可以提高数据库操作的执行效率、性能和安全性,特别适用于频繁执行相同或类似SQL语句的场景。在使用JDBC编程或持久层框架(如MyBatis)时,推荐使用预编译的方式执行数据库操作。

6.#{}和${}的区别?======被问+2

  1. ${}是拼接符,字符串替换,没有预编译处理。#{}是占位符,预编译处理,
  2. Mybatis在处理#{}时,#{}传入参数是以字符串传入,会将SQL中的#{}替换为?号,调用PreparedStatement的set方法来赋值
  3. Mybatis在处理 时,是原值传入 , 就是把 {}时,是原值传入,就是把 时,是原值传入,就是把{}替换成变量的值,相当于JDBC中的Statement编译
  4. 变量替换后,#{} 对应的变量自动加上单引号 ‘’;变量替换后,${} 对应的变量不会加上单引号 ‘’
  5. ${} 不能防止SQL 注入,#{} 可以有效的防止SQL注入,提高系统安全性;
  6. ${} 的变量替换是在 DBMS 外,#{} 的变量替换是在DBMS 中;

7.Mybatis模糊查询like语句该怎么写?需要注意什么?

  1. “%”#{question}”%” :正确写法之一
  2. 因为#{…}解析成sql语句时候,会在变量外侧自动加单引号’ ‘,所以这里 % 需要使用双引号” “,不能使用单引号 ’ ‘,不然会查不到任何结果

8.在mapper中如何传递多个参数?

  1. 顺序传参法—-不建议使用
  2. @Param注解传参法
  3. Map传参法
  4. java实体类传参法

9.当实体类中的属性名和表中的字段名不一样 ,怎么办?

  1. 通过在查询的SQL语句中定义字段名的别名,让字段名的别名和实体类的属性名一致
  2. 通过来映射字段名和实体类属性名的一一对应的关系。

PS:通过resultMap的方式

<?xml version="1.0" encoding="GBK" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.com.shallow.dao.UserMapper">
    <!--    resultMap-->
    <resultMap id="userMap" type="user">
        <!--column:数据库中的字段 property:实体类中的属性-->
<!--        <result column="id" property="id"/>-->
<!--        <result column="name" property="name"/>-->
        <result column="password" property="pwd"/>
    </resultMap>
    <select id=</
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

你不懂、、、

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

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

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

打赏作者

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

抵扣说明:

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

余额充值