IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 10道Mybatis经典面试题,赶快上车吧!???? -> 正文阅读

[Java知识库]10道Mybatis经典面试题,赶快上车吧!????

1.Mybatis中#{}和${}的区别是什么?

1.1 #{}方式能够很大程度防止sql注入(安全);

? ? ? ${}方式无法防止Sql注入。

1.2 在JDBC能使用占位符的地方,最好优先使用#{};

? ? ?在JDBC不支持使用占位符的地方,就只能使用${},典型情况就是动态参数。

1.3 #{}是预编译处理;

? ? ? ${}是字符串替换。

1.4 在处理#{}时,会将SQL中的#{}替换为?号,使用PreparedStatement的set方法来赋值;

? ? ? 在处理${}时,是把${}替换为变量的值。

2.Mybatis有几种分页方式?

Mybatis有两种分页,逻辑分页和物理分页。

逻辑分页:使用Mybatis自带的RowBounds进行分页,它是一次性查询很多数据,然后在数据中再进行检索。

?

物理分页:自己手写SQL分页或者使用分页插件PageHelper,去数据库查询指定条数的分页数据的形式。

3.RowBounds是一次性查询全部结果吗?为什么?

RowBounds表面是在“所有”数据中检索数据,其实并非是一次性查询出所有数据。

因为Mybatis是对jdbc的封装,在jdbc驱动中有一个FetchSize的配置,它规定了每次最多从数据库查询多少条数据,假如你要查询更多数据,它会在你执行next()的时候,去查询更的数据。就好比你去自动取款机取钱时一样,你要取10000元,但是取款机每次最多能取2500元,所以你要取4次才能把钱取完。只是对于jdbc来说,当你调用next()的时候会自动帮你完成查询工作。这样做的好处可以有效的防止内存溢出。

RowBounds的使用:

首先需要添加配置:

?查询的写法 offset偏移量 size 每页的大小:

?JDBC的FetchSize使用:

4.Mybatis逻辑分页和物理分页的区别是什么?

逻辑分页:逻辑分页是一次性查询很多数据,然后再结果中检索分页的数据,这样做弊端是需要消耗大量的内存、有内存溢出的风险、对数据库压力较大。

物理分页:物理分页是从数据库查询指定条数的数据,弥补了一次性全部查出的所有数据的种种缺点,比如需要大量的内存,对数据库查询压力较大等问题。

5.Mybatis是否支持延迟加载?延迟加载的原理是什么?

Mybatis支持延迟加载,设置lazyLoadingEnabled=true即可。

延迟加载的原理是调用的时候加载,而不是再初始化的时候就加载信息。

比如调用a.getB().getName(),这个时候发现a.getB()的值为null,此时会单独触发事先保存好的关联B对象的SQL,先查询出来B,然后再调用a.setB(b),而这时候再调用a.getB().getName()就有值了,这就是延迟加载的基本原理。

6.说一下mybatis的一级缓存和二级缓存?

一级缓存:基于?PerpetualCache 的 HashMap 本地缓存,它的声明周期是和 SQLSession 一致的,有多个 SQLSession 或者分布式的环境中数据库操作,可能会出现脏数据。当 Session flush 或 close 之后,该 Session 中的所有 Cache 就将清空,默认一级缓存是开启的。

二级缓存:也是基于?PerpetualCache 的 HashMap 本地缓存,不同在于其存储作用域为 Mapper 级别的,如果多个SQLSession之间需要共享缓存,则需要使用到二级缓存,并且二级缓存可自定义存储源,如 Ehcache。默认不打开二级缓存,要开启二级缓存,使用二级缓存属性类需要实现 Serializable 序列化接口(可用来保存对象的状态)。

7.Mybatis和hibernate的区别有哪些?

灵活性:MyBatis 更加灵活,自己可以写 SQL 语句,使用起来比较方便。

可移植性:MyBatis 有很多自己写的 SQL,因为每个数据库的 SQL 可以不相同,所以可移植性比较差。

学习和使用门槛:MyBatis 入门比较简单,使用门槛也更低。

二级缓存:hibernate 拥有更好的二级缓存,它的二级缓存可以自行更换为第三方的二级缓存。

8.Mybatis有哪些执行器(Executor)?

?MyBatis有三种基本的Executor执行器:

????????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 批处理相同。

9.Mybatis分页插件的实现原理是什么?

  1. 使用Mybatis插件(也称为拦截器)机制。对需要使用分页的功能进行增强,也就是重写sql语句,根据不同的数据生产不同的分页语句
  2. mysql会生产limit语句

注意:在这提醒各位mysql是使用limit语句,但是Oracle借助的rownum生成对应子查询语句

10.简述一下Mybatis 的编程步骤

1.创建 SqlSessionFactory
2.通过 SqlSessionFactory 创建 SqlSession
3.通过 sqlsession 执行数据库操作
4.调用 session.commit()提交事务
5.调用 session.close()关闭会话

作者:筱白爱学习!!

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-08-17 15:15:56  更:2021-08-17 15:16:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 22:54:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码