数据库高频面试题汇总

数据库基础知识
1、为什么要使用数据库
2、什么是SQL?
3、什么是MySQL?
4、数据库三大范式是什么
5、mysql有关权限的表都有哪几个
6、MySQL的binlog有有几种录入格式?分别有什么区别?

数据类型
1、mysql有哪些数据类型


1、MySQL存储引擎MyISAM与InnoDB区别
2、MyISAM索引与InnoDB索引的区别?
3、InnoDB引擎的4大特性
4、存储引擎选择

索引
1、什么是索引?
2、索引有哪些优缺点?
3、索引使用场景(重点)
4、索引有哪几种类型?
5、索引的数据结构(b树,hash)
6、索引的基本原理
7、索引算法有哪些?
8、索引设计的原则?
9、创建索引的原则(重中之重)
10、创建索引的三种方式,删除索引
11、创建索引时需要注意什么?
12、使用索引查询一定能提高查询的性能吗?为什么
13、百万级别或以上的数据如何删除
14、前缀索引
15、什么是最左前缀原则?什么是最左匹配原则
16、B树和B+树的区别
17、使用B树的好处
18、使用B+树的好处
19、Hash索引和B+树所有有什么区别或者说优劣呢?
20、数据库为什么使用B+树而不是B树
21、B+树在满足聚簇索引和覆盖索引的时候不需要回表查询数据,
22、什么是聚簇索引?何时使用聚簇索引与非聚簇索引
23、非聚簇索引一定会回表查询吗?
24、联合索引是什么?为什么需要注意联合索引中的顺序?


1、什么是数据库事务?
2、事物的四大特性(ACID)介绍一下?
3、什么是脏读?幻读?不可重复读?
4、什么是事务的隔离级别?MySQL的默认隔离级别是什么?


1、对MySQL的锁了解吗
2、隔离级别与锁的关系
3、按照锁的粒度分数据库锁有哪些?锁机制与InnoDB锁算法
4、从锁的类别上分MySQL都有哪些锁呢?像上面那样子进行锁定岂不是有点阻碍并发效率了
5、MySQL中InnoDB引擎的行锁是怎么实现的?
6、InnoDB存储引擎的锁的算法有三种
7、什么是死锁?怎么解决?
8、数据库的乐观锁和悲观锁是什么?怎么实现的?

视图
1、为什么要使用视图?什么是视图?
2、视图有哪些特点?
3、视图的使用场景有哪些?
4、视图的优点
5、视图的缺点
6、什么是游标?

存储过程与函数
1、什么是存储过程?有哪些优缺点?

发器
1、什么是触发器?触发器的使用场景有哪些?
2、MySQL中都有哪些触发器?

常用SQL语句
1、SQL语句主要分为哪几类
2、超键、候选键、主键、外键分别是什么?
3、SQL 约束有哪几种?
4、六种关联查询
5、什么是子查询
6、子查询的三种情况
7、mysql中 in 和 exists 区别
8、varchar与char的区别
9、varchar(50)中50的涵义
10、int(20)中20的涵义
11、mysql为什么这么设计
12、mysql中int(10)和char(10)以及varchar(10)的区别
13、FLOAT和DOUBLE的区别是什么?
14、drop、delete与truncate的区别
15、UNION与UNION ALL的区别?

SQL优化
1、如何定位及优化SQL语句的性能问题?创建的索引有没有被使用到?或者说怎么才可以知道这条语句运行很慢的原因?
2、SQL的生命周期?
3、大表数据查询,怎么优化
4、超大分页怎么处理?
5、mysql 分页
6、慢查询日志
7、关心过业务系统里面的sql耗时吗?统计过慢查询吗?对慢查询都怎么优化过?
8、为什么要尽量设定一个主键?
9、主键使用自增ID还是UUID?
10、字段为什么要求定义为not null?
11、如果要存储用户的密码散列,应该使用什么字段进行存储?
12、优化查询过程中的数据访问
13、优化长难的查询语句
14、优化特定类型的查询语句
15、优化关联查询
16、优化子查询
17、优化LIMIT分页
18、优化UNION查询
19、优化WHERE子句

数据库优化
1、为什么要优化
2、数据库结构优化
3、MySQL数据库cpu飙升到500%的话他怎么处理?
4、大表怎么优化?某个表有近千万数据,CRUD比较慢,如何优化?分库分表了是怎么做的?分表分库了有什么问题?有用到中间件么?他们的原理知道么?
垂直分表:
适用场景
缺点
水平分表:
适用场景
水平切分的缺点
5、MySQL的复制原理以及流程
6、读写分离有哪些解决方案?
7、备份计划,mysqldump以及xtranbackup的实现原理
8、数据表损坏的修复方式有哪些?

答案详情如下:

#阿里巴巴钉钉21届实习招聘内推##面试题目#
全部评论
楼主,答案挂掉了,可以补一下吗
1 回复 分享
发布于 2020-09-02 11:51
mysql
点赞 回复 分享
发布于 2020-04-30 17:38
请问数据库一般找哪些岗位,后端开发吗?
点赞 回复 分享
发布于 2020-04-30 17:45
mysql
点赞 回复 分享
发布于 2020-05-01 14:21
mysql
点赞 回复 分享
发布于 2020-05-01 15:32
mysql
点赞 回复 分享
发布于 2020-05-03 23:30
楼主,答案没有了
点赞 回复 分享
发布于 2020-07-30 20:21
mysql
点赞 回复 分享
发布于 2020-09-15 10:23
答案呢
点赞 回复 分享
发布于 2020-10-13 18:50
求答案
点赞 回复 分享
发布于 2022-03-30 21:49

相关推荐

#南大通用# 其实我是一个很少愿意写这个的人,但对于该公司,我确实有不理解的地方,也没处问,只能把从头到尾秋招的经历和大家说说。首先我投的是该公司的数据库测试工程师的岗位,投完之后有个笔试题,题还行,不难,有选择和编程,也是顺利通过了;然后过了一阵接收到了该公司的邮件,建了一个微信群,通知我们后续面试,之前说是三轮,群面,技术面和综面,然后群面大家都了解了,无领导小组讨论,我们这组是七个人(本来应该是九个),然后不得不说大家的实力都很不错,有发一区文章的,有科大讯飞实习的,有OPPO实习的,我确实啥也没有,而且还不是软件工程相关专业的(我是通信工程专业的),当时听到他们介绍确实很慌,但大家也知道无领导面试不比这样,最终呢,我也是通过我这i人硬装e人,干掉了五个人,顺利进入了下一轮;然后下一轮一样,先拉群,然后就说是综面了,不知道为什么技术面取消了,原本我以为综面中会有技术知识,我也是背了三天的八股文,但最后面试的时候,真的,一个专业知识没问,问我,家哪的,期望薪资多少,有什么优势等等那些问题,然后我看面试官笑呵的回复我,交谈甚欢,我以为肯定过了,谁成想今天一问刷掉了。到现在我也没想明白,哪块出现了问题?难道是薪资?这家公司在天津,不供吃不供住,我双非硕士要个11-12k,我感觉,没毛病吧(他在牛客这个岗位上写的可是10-20k的),反正说啥都晚了,就是不理解在哪块出现了问题,你要是技术面给我刷了,我可以说我认了,毕竟才学了半年的测试,但一个综面给我刷了,我不理解了...
查看3道真题和解析
点赞 评论 收藏
分享
评论
5
196
分享
牛客网
牛客企业服务