数据库面试题
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.内连接、左外连接、右外连接
内连接:是一种一一映射关系,两张表都显示出来。
左外连接:左边表所有数据都显示出来,右边表只显示公共的部分。
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的两种映射方式:
- 通过XML映射
- 通过注解
2.Mybatis的优点及缺点
优点:
1.减少代码冗余,不需要手动开关连接。
2.SQL写在XML里,解除与代码的耦合,便于管理。
3.提供映射标签,支持对象与数据库字段的ORM关系映射。
缺点:SQL语句编写工作量大。
3.#{} 和 ${}的区别
#{}是预编译处理,${}是字符串替换。
Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;
Mybatis在处理 时 , 就 是 把 {}时,就是把 时,就是把{}替换成变量的值。
使用#{}可以有效的防止SQL注入,提高系统安全性。
4.实体类属性名和表中字段名不一样,怎么办?
方式一:在查询的SQL语句中定义字段的别名,别名和实体类的属性名一致。
方式二:通过来映射字段名和实体类的一一对应关系。
5.模糊查询like语句怎么写?
6.Dao接口的工作原理是什么?Dao接口里的方法,参数不同时,方法能重载吗?
DAO接口的工作原理是jdk动态代理,mybatis运行时会使用JDK动态代理为Mapper接口产生代理对象proxy,代理对象会拦截接口方法,转而执行MapperStatement所代表的SQL,然后将结果返回。
接口中方法不能重载,因为接口中方法名不能重复,是使用全限名和方法名的保存和寻找策略。
7.Mybatis是如何将SQL执行结果封装为目标对象并返回的?都有哪些映射形式?
1.使用标签,逐一定义列名与实体类属性名的映射关系。
2.设置列的别名为实体类的属性名。
有了列名与属性名映射关系后,mybatis通过反射创建对象,用反射给对象的属性赋值并返回,找不到映射关系的属性,无法赋值。
8.自增主键回填以及实现方法?
新增一条数据成功后,将这条数据的主键封装到实体类中,并查看主键的值。
实现一:使用insert标签的子标签selectKey实现;
实现二:使用insert标签的属性useGeneratedKeys,keyProperty,keyColumn实现;
9.动态SQL有什么用?执行原理?都有哪些动态SQL?
作用:可以在 Xml 映射文件内,以标签的形式编写动态 sql,执行原理是根据表达式的值 完成逻辑判断并动态拼接 sql 的功能。
执行原理:根据表达式的值 完成逻辑判断并动态拼接sql的功能。
Mybatis提供了9种动态sql标签:trim | where | set | foreach | if | choose | when | otherwise | bind。
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节点配置。(分步查询)