1、说一下 MySQL 执行一条查询语句的内部执行过程?
* 客户端先通过连接器连接到 MySQL 服务器。
* 连接器权限验证通过之后,先查询是否有查询缓存,如果有缓存(之前执行过此语句)则直接返回缓存数据,如果没有缓存则进入分析器。
* 分析器会对查询语句进行语法分析和词法分析,判断 SQL 语法是否正确,如果查询语法错误会直接返回给客户端错误信息,如果语法正确则进入优化器。
* 优化器是对查询语句进行优化处理,例如一个表里面有多个索引,优化器会判别哪个索引性能更好。
* 优化器执行完就进入执行器,执行器就开始执行语句进行查询比对了,直到查询到满足条件的所有数据,然后进行返回。
2、MySQL 提示“不存在此列”是执行到哪个节点报出的?
此错误是执行到分析器阶段报出的,因为 MySQL 会在分析器阶段检查 SQL 语句的正确性。
3、MySQL 查询缓存的功能有何优缺点?
优点是效率高,如果已经有缓存则会直接返回结果。
查询缓存的缺点是失效太频繁导致缓存命中率比较低,任何更新表操作都会清空查询缓存,因此导致查询缓存非常容易失效。
4、如何关闭 MySQL 的查询缓存功能?
MySQL 查询缓存默认是开启的,配置 querycachetype 参数为 DEMAND(按需使用)关闭查询缓存,MySQL 8.0
之后直接删除了查询缓存的功能。
5、MySQL 的常用引擎都有哪些?
MySQL 的常用引擎有 InnoDB、MyISAM、Memory 等,从 MySQL 5.5.5 版本开始 InnoDB
就成为了默认的存储引擎。
6、MySQL 可以针对表级别设置数据库引擎吗?怎么设置?
可以。
在 create table 语句中使用 engine=引擎名(比如Memory)来设置此表的存储引擎。
create table student( id int primary key auto_increment, username
varchar(120), age int ) ENGINE=Memory
7、常用的存储引擎 InnoDB 和 MyISAM 有什么区别?
InnoDB 和 MyISAM 最大的区别是 InnoDB 支持事务,而 MyISAM 不支持事务。
区别如下:
* InnoDB 支持崩溃后安全恢复,MyISAM 不支持崩溃后安全恢复;
* InnoDB 支持行级锁,MyISAM 不支持行级锁,只支持到表锁;
* InnoDB 支持外键,MyISAM 不支持外键;
* MyISAM 支持 FULLTEXT 类型的全文索引,InnoDB 不支持 FULLTEXT 类型的全文索引,但是 InnoDB 可以使用
sphinx 插件支持全文索引,并且效果更好;
* InnoDB 主键查询性能高于 MyISAM。
8、InnoDB 有哪些特性?
(1)插入缓冲(insert buffer):
对于非聚集索引的插入和更新,不是每一次直接插入索引页中,而是首先判断插入的非聚集索引页是否在缓冲池中,如果在,则直接插入,否则,先放入一个插入缓冲区中。
好似欺骗数据库这个非聚集的索引已经插入到叶子节点了,然后再以一定的频率执行插入缓冲和非聚集索引叶子节点的合并操作,这时通常能将多个插入合并到一个操作中,这就大大提高了对非聚集索引执行插入和修改操作的性能。
(2)两次写(double write):
两次写给 InnoDB 带来的是可靠性,主要用来解决部分写失败(partial page write)。
doublewrite 由两部分组成,一部分是内存中的 doublewrite buffer ,大小为
2M,另外一部分就是物理磁盘上的共享表空间中连续的 128 个页,即两个区,大小同样为 2M。
当缓冲池的作业刷新时,并不直接写硬盘,而是通过 memcpy 函数将脏页先拷贝到内存中的 doublewrite buffer,之后通过
doublewrite buffer 再分两次写,每次写入 1M 到共享表空间的物理磁盘上,然后马上调用 fsync 函数,同步磁盘。
(3)自适应哈希索引(adaptive hash index):
由于 InnoDB 不支持 hash 索引,但在某些情况下 hash 索引的效率很高,于是出现了 adaptive hash index
功能, InnoDB 存储引擎会监控对表上索引的查找,如果观察到建立 hash 索引可以提高性能的时候,则自动建立 hash 索引。
9、什么是独立表空间和共享表空间?它们的区别是什么?
共享表空间:指的是数据库的所有的表数据、索引文件全部放在一个文件中,默认这个共享表空间的文件路径在 data 目录下。
独立表空间:每一个表都将会以独立的文件方式来进行存储。
共享表空间和独立表空间最大的区别是如果把表放在共享表空间,即使表删除了空间也不会删除,所以表依然很大,而独立表空间如果删除表就会清除空间。
10、如何设置独立表空间?
独立表空间是由参数 innodbfileper_table 控制的,把它设置成 ON 就是独立表空间了,从 MySQL 5.6.6
版本之后,这个值就默认是 ON 了。
11、表的结构信息存在哪里?
表结构定义占有的存储空间比较小,在 MySQL 8 之前,表结构的定义信息存在以 .frm 为后缀的文件里,在 MySQL 8
之后,则允许把表结构的定义信息存在系统数据表之中。
12、什么是覆盖索引?
只需扫描索引就可以得到想要的数据而无须回表。
13、什么叫回表查询?
普通索引查询到主键索引后,回到主键索引树搜索的过程,我们称为回表查询。
14、如果把一个 InnoDB 表的主键删掉,是不是就没有主键,就没办法进行回表查询了?
可以回表查询,如果把主键删掉了,那么 InnoDB 会自己生成一个长度为 6 字节的 rowid 作为主键。
15、执行一个 update 语句以后,我再去执行 hexdump 命令直接查看 ibd 文件内容,为什么没有看到数据有改变呢?
可能是因为 update 语句执行完成后,InnoDB 只保证写完了 redo log、内存,可能还没来得及将数据写到磁盘。
16、内存表和临时表有什么区别?
内存表,指的是使用 Memory 引擎的表,建表语法是 create table …
engine=memory。这种表的数据都保存在内存里,系统重启的时候会被清空,但是表结构还在。
临时表,可以使用各种引擎类型 。如果是使用 InnoDB 引擎或者 MyISAM 引擎的临时表,写数据的时候是写到磁盘上的。
17、并发事务会带来哪些问题?
脏读、修改丢失、不可重复读、幻读
18、什么是脏读和幻读?
脏读是一个事务在处理过程中读取了另外一个事务未提交的数据;
幻读是指同一个事务内多次查询返回的结果集不一样(比如增加了或者减少了行记录)。
19、为什么会出现幻读?幻读会带来什么问题?
因为行锁只能锁定存在的行,针对新插入的操作没有限定,所以就有可能产生幻读。
幻读带来的问题如下:对行锁语义的破坏;破坏了数据一致性。
20、如何避免幻读?
MySQL 存储引擎 InnoDB 隔离级别 RR 解决了幻读问题
21、VARCHAR 和 CHAR 的区别是什么?分别适用的场景有哪些?
VARCHAR 和 CHAR 最大区别就是,VARCHAR 的长度是可变的,而 CHAR 是固定长度。
CHAR 比较适合长度较短的字段和固定长度的字段,如身份证号、手机号等,反之则适合使用 VARCHAR。
22、MySQL 存储金额应该使用哪种数据类型?为什么?
MySQL 存储金额应该使用 decimal ,因为如果存储其他数据类型,比如 float 有导致小数点后数据丢失的风险。
当然,也可以在存储为 int 类型,在存储前将 19.38 元转换为 1938 分,再存储到数据库
23、limit 10,2 的含义是什么?
去除前10条数据之后,查询两条信息。
24、now() 和 current_date() 有什么区别?
now() 返回当前时间包含日期和时分秒 2019-05-04 19:23:45
current_date() 只返回当前时间 2019-05-04
25、如何去重计算总条数?
使用 distinct 去重,使用 count 统计总条数
select count(distinct f) from t
26、删除表的数据有几种方式?它们有什么区别?
删除数据有两种方式:delete 和 truncate,它们的区别如下:
delete 可以添加 where 条件删除部分数据,truncate 不能添加 where 条件只能删除整张表;
delete 的删除信息会在 MySQL 的日志中记录,而 truncate 的删除信息不被记录在 MySQL 的日志中,因此 detele
的信息可以被找回而 truncate 的信息无法被找回;
truncate 因为不记录日志所以执行效率比 delete 快。
delete from t where username='redis'; truncate table t;
27、MySQL 中支持几种模糊查询?它们有什么区别?
MySQL 中支持两种模糊查询:regexp 和 like,like 是对任意多字符匹配或任意单字符进行模糊匹配,而 regexp
则支持正则表达式的匹配方式,提供比 like 更多的匹配方式。
regexp 和 like 的使用示例如下:
select * from person where uname like '%SQL%'; select from person where uname
regexp '.SQL*.';
28、count(column) 和 count() 有什么区别?**
count(column) 和 count() 最大区别是统计结果可能不一致,count(column) 统计不会统计列值为 null
的数据,而 count() 则会统计所有信息,所以最终的统计结果可能会不同。
29、什么是视图?如何创建视图?
视图是一种虚拟的表,具有和物理表相同的功能,可以对视图进行增、改、查操作。视图通常是一个表或者多个表的行或列的子集。 视图创建脚本如下:
create view vname as select column_names from table_name where condition
30、视图有哪些优点?
获取数据更容易,相对于多表查询来说;
视图能够对机密数据提供安全保护;
视图的修改不会影响基本表,提供了独立的操作单元,比较轻量。
31、使用 delete 误删数据怎么找回?
可以用 Flashback 工具通过闪回把数据恢复回来。
32、Flashback 恢复数据的原理是什么?
Flashback 恢复数据的原理是是修改 binlog 的内容,拿回原库重放,从而实现数据找回。