数据库及mybatis常见面试题总结(通俗易懂)

数据库面试题

1.事务的四大特性

原子性:一个事务不可分割,要么都执行,要么都不执行。

一致性:事务前后,数据总额一致。

隔离性:事务之间互不打扰。

持久性:一旦事务提交,数据会永久保存。

2.事务隔离级别

读未提交:一个事务可以读取另一个未提交事务的数据,最低级别。

读已提交:一个事务可以读取另一个已提交事务的数据,避免了脏读。

可重复读:事务开启后不再允许修改操作。可避免脏读,不可重复读。

串行:是最高隔离级别,可避免脏读,不可重复读,幻读。效率较低,一般不使用。

MySQL默认是可重复读。

3.事务并发引起的三大问题

脏读:指一个事务读取了另外一个事务未提交的数据。

不可重复读:前后多次读取,数据内容不一致

幻读:前后多次读取,数据总量不一致

4.MySQL主要索引类型

主键索引:非空、唯一,一个表只能有一个

普通索引:无限制

唯一索引:唯一

组合索引:指多个字段上创建的索引

全文索引:查找文本的关键字,MySQL 5.6之后MYLSAM和InnoDB都支持。

5.索引的作用及优缺点

作用是:提高查询效率

优点:查询效率高,降低数据IO成本,降低CPU的消耗。

缺点:占用磁盘空间,增删改慢,因为要修改索引。

6.数据库三大范式

第一范式:原子性 表中每一列都是不可拆分的。

第二范式:在第一范式基础上,表中每一列都依赖于主键;一张表只描述一件事。

第三范式:从表的外键必须使用主表的主键。

7.MySQL中常用的函数

limit,order by,between,group by

聚合函数:count,max,min,sum,avg

8.使用like ‘a%’ 、like’%a’、like’%a%'查询时是否会使用索引

‘a%'会,

其他不会,因为这些查询会导致全表扫描,放弃索引。

9.内连接、左外连接、右外连接

内连接:是一种一一映射关系,两张表都显示出来。

在这里插入图片描述

左外连接:左边表所有数据都显示出来,右边表只显示公共的部分。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-w4esZQmH-1600083217354)(C:\Users\Ali\AppData\Roaming\Typora\typora-user-images\1599553814038.png)]

10.truncate、drop和delete的区别

delete:将表中数据一条一条删除,不破坏表结构

truncate:将整张表摧毁,重建一个表结构一样的新表

drop:直接删除表

11.什么是蠕虫复制

1、创建student2表,student2结构和student表结构一样

​ create table student2 like student;

2、将student表中的数据添加到student2表中

​ insert into student2 select * from student;

12.where和having的区别

where在分组之前进行过滤

having必须和group by一起使用

select * from 表名 where 条件 group by 字段 having 条件;

13.分页查询SQL

select * from 表名 limit offset,row_count;

offset表示跳过几个,row_count表示显示几条

14.Mysql 的存储引擎,myisam和innodb的区别

myisam不支持事务,适用于频繁查询的应用。表锁,不会出现死锁,适合小数据,小并发。

innodb支持事务,适用于插入和更新操作较多的应用,默认是行锁,适合大数据,大并发。

15.char和varchar的区别?

char固定长度,varchar可变长度

16.什么是存储过程?

存储过程是一个预编译的SQL语句,只需创建一次,后面程序可以直接调用,调用格式为:call 存储过程名

17.数据库的优化

尽量避免全表扫描,比如用模糊查询,*查询

18.连接池

核心思想是连接的复用,通过建立连接池,每次从连接池中获取连接,用完再放回连接池,省略了创建和销毁连接的过程,提高了性能。

=====================================================================

Mybatis面试题

1.Mybatis介绍

1.mybatis是一个可自定义SQL、存储过程、和高级映射的持久层(半ORM -对象关系映射)框架。

2.舍弃了大部分JDBC代码。

3.专注SQL本身,是一个灵活的DAO层解决方案。

MyBatis的两种映射方式:

  1. 通过XML映射
  2. 通过注解

2.Mybatis的优点及缺点

优点:

1.减少代码冗余,不需要手动开关连接。

2.SQL写在XML里,解除与代码的耦合,便于管理。

3.提供映射标签,支持对象与数据库字段的ORM关系映射。

缺点:SQL语句编写工作量大。

3.#{} 和 ${}的区别

#{}是预编译处理,${}是字符串替换。

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

Mybatis在处理 时 , 就 是 把 {}时,就是把 {}替换成变量的值。

使用#{}可以有效的防止SQL注入,提高系统安全性。

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

方式一:在查询的SQL语句中定义字段的别名,别名和实体类的属性名一致。

方式二:通过来映射字段名和实体类的一一对应关系。

数据库及mybatis常见面试题总结(通俗易懂)_第1张图片

5.模糊查询like语句怎么写?

数据库及mybatis常见面试题总结(通俗易懂)_第2张图片

6.Dao接口的工作原理是什么?Dao接口里的方法,参数不同时,方法能重载吗?

DAO接口的工作原理是jdk动态代理,mybatis运行时会使用JDK动态代理为Mapper接口产生代理对象proxy,代理对象会拦截接口方法,转而执行MapperStatement所代表的SQL,然后将结果返回。

接口中方法不能重载,因为接口中方法名不能重复,是使用全限名和方法名的保存和寻找策略。

7.Mybatis是如何将SQL执行结果封装为目标对象并返回的?都有哪些映射形式?

1.使用标签,逐一定义列名与实体类属性名的映射关系。

2.设置列的别名为实体类的属性名。

有了列名与属性名映射关系后,mybatis通过反射创建对象,用反射给对象的属性赋值并返回,找不到映射关系的属性,无法赋值。

8.自增主键回填以及实现方法?

新增一条数据成功后,将这条数据的主键封装到实体类中,并查看主键的值。

实现一:使用insert标签的子标签selectKey实现;

实现二:使用insert标签的属性useGeneratedKeys,keyProperty,keyColumn实现;

数据库及mybatis常见面试题总结(通俗易懂)_第3张图片

9.动态SQL有什么用?执行原理?都有哪些动态SQL?

作用:可以在 Xml 映射文件内,以标签的形式编写动态 sql,执行原理是根据表达式的值 完成逻辑判断并动态拼接 sql 的功能。

执行原理:根据表达式的值 完成逻辑判断并动态拼接sql的功能。

Mybatis提供了9种动态sql标签:trim | where | set | foreach | if | choose | when | otherwise | bind。

数据库及mybatis常见面试题总结(通俗易懂)_第4张图片

10.Xml映射文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签?

答: 、、、、,加上动态sql的9个标签,其中为sql片段标签,通过标签引入sql片段,为不支持自增的主键生成策略标签。

11.Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复?

不同的XML映射文件,如果配置了namespace,id可重复。如未配置namespace,则id不可重复。现在Mybatis版本要求必须配置namespace,所以id是可重复的。

12.为什么说Mybatis是半自动ORM映射工具?

Hibernate属于全自动ORM映射工具,使用Hibernate查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。而Mybatis在查询关联对象或关联集合对象时,需要手动编写sql来完成,所以,称之为半自动ORM映射工具。

13.mybatis延迟(懒)加载的实现原理及好处

Mybatis仅支持association关联对象和collection关联集合对象的延迟加载,association:一对一,collection:一对多查询。在Mybatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false。

实现原理:使用CGLIB创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调用a.getB().getName(),拦截器invoke()方法发现a.getB()是null值,那么就会单独发送事先保存好的查询关联B对象的sql,把B查询上来,然后调用a.setB(b),于是a的对象b属性就有值了,接着完成a.getB().getName()方法的调用。这就是延迟加载的基本原理。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YGxhmNwq-1600083217368)(C:\Users\Ali\AppData\Roaming\Typora\typora-user-images\1599636883000.png)]

延迟加载的好处:先从单表查询、需要时再从关联表去关联查询,大大提高 数据库性能,因为查询单表要比关联查询多张表速度要快。

14.Mybatis的一级、二级缓存

一级缓存:(本地缓存)作用域:SqlSession级别

mybatis第一次查询到数据后,会将数据存入到一级缓存中。当再次查询相同的数据时,mybatis会将缓存中的数据直接拿出来返回,不再从数据库中查询;

二级缓存:(全局缓存) 作用域:namespace级别

  • 在一个sqlSession,进行了一次查询,会把查询结果存入一级缓存;
  • 当sqlSession关闭之后,mybatis会把一级缓存中的数据存入二级缓存中;
  • 当我们再次发生相同的查询时,会从二级缓存中命中;

二级缓存作用域更大

15、Mybatis 是如何进行分页的?分页插件的原理是什么?

Mybatis 使用 RowBounds 对象进行分页, 它是针对 ResultSet 结果集执行的内存分页,而非物理分页。可以在 sql 内直接书写带有物理分页的参数来完成物理分页功能, 也可以使用分页插件来完成物理分页。

分页插件的基本原理是使用 Mybatis 提供的插件接口, 实现自定义插件, 在插件的拦截方法内拦截待执行的 sql,然后重写 sql,根据 dialect 方言,添加对应的物理分页语句和物理分页参数。

16.一对一,一对多查询

查询步骤:需求分析、在实体类中添加关联、编写接口方法、编写XML映射文件、测试

映射文件编写如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3HGE0M8f-1600083217370)(C:\Users\Ali\AppData\Roaming\Typora\typora-user-images\1599641489179.png)]

17、MyBatis实现一对多查询有几种方式,怎么操作的?

有联合查询和嵌套查询。

联合查询是几个表联合查询,只查询一次,通过在resultMap里面的collection节点配置一对多的类就可以完成;(多表关联查询)

嵌套查询是先查一个表,根据这个表里面的 结果的外键id,去再另外一个表里面查询数据,也是通过配置collection,但另外一个表的查询通过select节点配置。(分步查询)

你可能感兴趣的:(Java数据库,mybatis,mysql,mybatis)