MySQL数据库面试题

目录

数据库基础知识

为什么要使用数据库

在这里插入图片描述

什么是SQL?

在这里插入图片描述

什么是MySQL?

在这里插入图片描述

数据库三大范式是什么

在这里插入图片描述

mysql有关权限的表都有哪几个

在这里插入图片描述

MySQL的binlog有有几种录入格式?分别有什么区别?

在这里插入图片描述

数据类型

mysql有哪些数据类型

在这里插入图片描述
在这里插入图片描述

引擎

MySQL存储引擎MyISAM与InnoDB区别

在这里插入图片描述

MyISAM索引与InnoDB索引的区别?

在这里插入图片描述

InnoDB引擎的4大特性

在这里插入图片描述

存储引擎选择

在这里插入图片描述

索引

什么是索引?

在这里插入图片描述

索引有哪些优缺点?

在这里插入图片描述

索引使用场景(重点)

在这里插入图片描述

索引有哪几种类型?

在这里插入图片描述

索引的数据结构(b树,hash)

在这里插入图片描述

索引的基本原理

在这里插入图片描述

索引算法有哪些?

在这里插入图片描述

索引设计的原则?

在这里插入图片描述

创建索引的原则(重中之重)

在这里插入图片描述

创建索引的三种方式,删除索引

在这里插入图片描述

创建索引时需要注意什么?

在这里插入图片描述

使用索引查询一定能提高查询的性能吗?为什么

在这里插入图片描述

百万级别或以上的数据如何删除

在这里插入图片描述

前缀索引

在这里插入图片描述

什么是最左前缀原则?什么是最左匹配原则

在这里插入图片描述

B树和B+树的区别

在这里插入图片描述

使用B树的好处

在这里插入图片描述

使用B+树的好处

在这里插入图片描述

Hash索引和B+树所有有什么区别或者说优劣呢?

在这里插入图片描述

数据库为什么使用B+树而不是B树

在这里插入图片描述

B+树在满足聚簇索引和覆盖索引的时候不需要回表查询数据,

在这里插入图片描述

什么是聚簇索引?何时使用聚簇索引与非聚簇索引

在这里插入图片描述

非聚簇索引一定会回表查询吗?

在这里插入图片描述

联合索引是什么?为什么需要注意联合索引中的顺序?

在这里插入图片描述

事务

什么是数据库事务?

在这里插入图片描述

事物的四大特性(ACID)介绍一下?

原子性(Atomicity)
一致性(Consistency)
隔离性(Isolation)
持久性(Durability)
在这里插入图片描述

什么是脏读?幻读?不可重复读?

在这里插入图片描述

什么是事务的隔离级别?MySQL的默认隔离级别是什么?

在这里插入图片描述

对MySQL的锁了解吗

在这里插入图片描述

隔离级别与锁的关系

在这里插入图片描述

按照锁的粒度分数据库锁有哪些?锁机制与InnoDB锁算法

在这里插入图片描述

从锁的类别上分MySQL都有哪些锁呢?像上面那样子进行锁定岂不是有点阻碍并发效率了

在这里插入图片描述

MySQL中InnoDB引擎的行锁是怎么实现的?

在这里插入图片描述

InnoDB存储引擎的锁的算法有三种

在这里插入图片描述

什么是死锁?怎么解决?

在这里插入图片描述

数据库的乐观锁和悲观锁是什么?怎么实现的?

在这里插入图片描述

视图

为什么要使用视图?什么是视图?

在这里插入图片描述

视图有哪些特点?

在这里插入图片描述

视图的使用场景有哪些?

在这里插入图片描述

视图的优点

在这里插入图片描述

视图的缺点

在这里插入图片描述

什么是游标?

在这里插入图片描述

存储过程与函数

什么是存储过程?有哪些优缺点?

在这里插入图片描述

触发器

什么是触发器?触发器的使用场景有哪些?

在这里插入图片描述

MySQL中都有哪些触发器?

在这里插入图片描述

常用SQL语句

SQL语句主要分为哪几类

在这里插入图片描述

超键、候选键、主键、外键分别是什么?

在这里插入图片描述

SQL 约束有哪几种?

在这里插入图片描述

六种关联查询

在这里插入图片描述
交叉连接

SELECT * FROM A,B,C或者SELECT * FROM A CROSS JOIN B (CROSS JOIN C)

没有任何关联条件,结果是笛卡尔积,结果集会很大,没有意义,很少使用

内连接(INNER JOIN)

SELECT * FROM A,B WHERE A.id=B.id或者SELECT * FROM A INNER JOIN B ON A.id=B.id
多表中同时符合某种条件的数据记录的集合,INNER JOIN可以缩写为JOIN

在这里插入图片描述
外连接(LEFT JOIN/RIGHT JOIN)
在这里插入图片描述

联合查询(UNION与UNION ALL)

SELECT * FROM A UNION SELECT * FROM B UNION …

在这里插入图片描述

全连接(FULL JOIN)

SELECT * FROM A LEFT JOIN B ON A.id=B.id UNIONSELECT * FROM A RIGHT JOIN B ON A.id=B.id

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

什么是子查询

在这里插入图片描述

子查询的三种情况

  1. 子查询是单行单列的情况:结果集是一个值,父查询使用:=、 <、 > 等运算符
-- 查询工资最高的员工是谁? 
select  * from employee where salary=(select max(salary) from employee);   
  1. 子查询是多行单列的情况:结果集类似于一个数组,父查询使用:in 运算符
   -- 查询工资最高的员工是谁? 
select  * from employee where salary=(select max(salary) from employee);   
  1. 子查询是多行多列的情况:结果集类似于一张虚拟表,不能用于where条件,用于select子句中做为子表
 -- 1) 查询出2011年以后入职的员工信息
-- 2) 查询所有的部门信息,与上面的虚拟表中的信息比对,找出所有部门ID相等的员工。
select * from dept d,  (select * from employee where join_date > '2011-1-1') e where e.dept_id =  d.id;    

-- 使用表连接:
select d.*, e.* from  dept d inner join employee e on d.id = e.dept_id where e.join_date >  '2011-1-1'  

mysql中 in 和 exists 区别

在这里插入图片描述

varchar与char的区别

在这里插入图片描述

varchar(50)中50的涵义

在这里插入图片描述

int(20)中20的涵义

在这里插入图片描述

mysql为什么这么设计在这里插入图片描述

mysql中int(10)和char(10)以及varchar(10)的区别

在这里插入图片描述

FLOAT和DOUBLE的区别是什么?

在这里插入图片描述

drop、delete与truncate的区别

在这里插入图片描述

UNION与UNION ALL的区别?

在这里插入图片描述

SQL优化

如何定位及优化SQL语句的性能问题?创建的索引有没有被使用到?或者说怎么才可以知道这条语句运行很慢的原因?

在这里插入图片描述
在这里插入图片描述

【推荐】SQL性能优化的目标:至少要达到 range 级别,要求是ref级别,如果可以是consts最好。
说明:
1) consts 单表中最多只有一个匹配行(主键或者唯一索引),在优化阶段即可读取到数据。
2) ref 指的是使用普通的索引(normal index)。
3) range 对索引进行范围检索。
反例:explain表的结果,type=index,索引物理文件全扫描,速度非常慢,这个index级别比较range还低,与全表扫描是小巫见大巫。

SQL的生命周期?

在这里插入图片描述

大表数据查询,怎么优化

在这里插入图片描述

超大分页怎么处理?

在这里插入图片描述

【推荐】利用延迟关联或者子查询优化超多分页场景。
说明:MySQL并不是跳过offset行,而是取offset+N行,然后返回放弃前offset行,返回N行,那当offset特别大的时候,效率就非常的低下,要么控制返回的总页数,要么对超过特定阈值的页数进行SQL改写。
正例:先快速定位需要获取的id段,然后再关联:
SELECT a.* FROM 表1 a, (select id from 表1 where 条件 LIMIT 100000,20 ) b where a.id=b.id

mysql 分页

在这里插入图片描述

慢查询日志

在这里插入图片描述

关心过业务系统里面的sql耗时吗?统计过慢查询吗?对慢查询都怎么优化过?

在这里插入图片描述

为什么要尽量设定一个主键?

在这里插入图片描述

主键使用自增ID还是UUID?

在这里插入图片描述

字段为什么要求定义为not null?

在这里插入图片描述

如果要存储用户的密码散列,应该使用什么字段进行存储?

在这里插入图片描述

优化查询过程中的数据访问

在这里插入图片描述

优化长难的查询语句

在这里插入图片描述

优化特定类型的查询语句

在这里插入图片描述

优化关联查询

在这里插入图片描述

优化子查询

在这里插入图片描述

优化LIMIT分页

在这里插入图片描述

优化UNION查询

在这里插入图片描述

优化WHERE子句

在这里插入图片描述

数据库优化

为什么要优化

在这里插入图片描述

数据库结构优化

在这里插入图片描述

MySQL数据库cpu飙升到500%的话他怎么处理?

在这里插入图片描述

大表怎么优化?某个表有近千万数据,CRUD比较慢,如何优化?分库分表了是怎么做的?分表分库了有什么问题?有用到中间件么?他们的原理知道么?

在这里插入图片描述
在这里插入图片描述

垂直分表

在这里插入图片描述

适用场景

在这里插入图片描述

缺点

在这里插入图片描述

水平分表:

在这里插入图片描述

适用场景

在这里插入图片描述

水平切分的缺点

在这里插入图片描述

在这里插入图片描述

数据库分片的两种常见方案

在这里插入图片描述

MySQL的复制原理以及流程

在这里插入图片描述
在这里插入图片描述

读写分离有哪些解决方案?

在这里插入图片描述

备份计划,mysqldump以及xtranbackup的实现原理

在这里插入图片描述

数据表损坏的修复方式有哪些?

在这里插入图片描述

原文链接:https://thinkwon.blog.csdn.net/article/details/104778621

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值