面试题千变万化,为什么总是会问MySQL?
前言
当你简历上写了 熟悉mysql关系型数据库时,那肯定免不了面试官对于myql索引.事务,慢查询等等的考察
那么到底什么是索引,索引的数据类型有哪些,它们的优缺点以及如何去排查那些慢SQL语句等,虚都莫虚,下面都给各位安排安排
面试开始
面试官 : 我看你简历上写了熟悉mysql,那谈谈你是如何筛选出慢mysql语句呢?
是它,是它,就是它,慢查询日志,这个时候你肯定要把主动权掌握在自己手里了,只要面试官不说停,谁拉我都绝对不能停下来的
深吸一口气,开始你对面试官最深情的告白
首先可以先通过 show variables like ‘slow_query%’ 来确定慢查询是否开启,如果没有则通过 set global slow_query_log=‘ON’ 开启慢查询
其次我们可以设置慢查询日志的位置( set global slow_query_log_file )和设置超过多少秒( set global long_query_time )记录下慢sql,
这样就可以在指定的目录下查看日志,从而找出慢sql语句.
这个时候好像第一个问题已经回答完了,但是停是不可能停下来的,一辈子都不可能
慢sql的原因有很多,其中典型的就是表的数据量太大,查询的时候走了全表查询从而导致查询时间长,这个时候我们可以给一些数据量大的表添加索引,当然也可以通过 set global log_queries_not_using_indexes=1 记录下没有走索引的sql语句
面试官 : 心想 看来对慢查询挺熟悉的,既然自己说到了索引,那我就问问有关索引的问题 ?
那行,你刚才说到了索引, 那你谈谈索引的模型都有哪些 ?
哈希表它是一种以key-value形式存在的,只要输入key,就能找到对应的value,当然多个key也会存在hash值相同的情况,这个时候解决方案就拉出一个链表,它在查询等值的情况下效率高,但是在区间查询上就没有办法了 ,毕竟不是有序的
面试官:那有没有其他的数据结构可以解决呢 ?
有序数组在等值和范围查询上非常的优秀,但是在更新数据时就很痛苦了,当我们在中间插入时,必须移动后面所有的记录,这个成本就非常的大了,毕竟数据库也是很辛苦了,所以有序数组一般只使用于存储静态存储引擎,例如你xx年的花呗记录这样不会改变的历史数据
面试官 :那你说说mysql默认是哪种数据结构呢 ,为什么呢
mysql数据库索引默认采用的是B+树这种数据结构,(因为B+树牛逼 ,当然是开玩笑的) 因为像hash这种数据结构无法进行范围查询,有序数组在插入时效率低,而B+树它是有序的,可以进行范围查询,并且树的高度低,提高了查询索引时磁盘的IO次数,提高了效率
面试官 : 小伙子看来还是不错,那你谈谈索引都有哪些类型?
不同的存储引擎,索引的类型是不一样的,像myisam存储引擎,其索引结构的叶子节点存储的是指向数据的指针,这种索引就是非聚簇索引;而 InnoDB将 数据存储与索引放到了一块,找到索引也就找到了数据 ,这种叫做聚簇索引
面试官:还有其他的索引吗?
在InnoDB中, 在聚簇索引之外创建的索引称之为辅助索引 .
辅助索引存储的是主键的值及本索引的值,因此我们通过索引拿到主键值后,再通过主键索引找到对应行的值,这个过程称为回表,(绝对不能停),我们也可以通过覆盖索引优化回表操作,提高性能.
覆盖索引:因为辅助索引存储的是索引列的值以及主键值 ,那么可以直接把查询索引列的值作为查询,这样就可以避免回表.
例如 : select id from tb where name = ‘xx’ 给name建立索引 这时候故作卡顿, 嗯,嗯 ,还有一种常用的索引.
面试官 : 联合索引是吧?你谈一谈
因为每张表只能用到一个索引,但是我们查询的条件不止一个,我们就可以创建联合索引,在使用联合索引的时候一定得小心,不然很容易导致索引失效,遵循 最左匹配原则,也就是如果索引 (a,b,c) ,查询条件为 a=1 and b>2 and c=3,遇到范围性条件( >、<、between、like左匹配 ),后面的列就无法使用索引了
面试官 : 这小伙子基础掌握得还可以 ,有点墨水, 今天MYSQL部分就先到这里
加入313782132,群内可领取学习资料、面试技巧、内推机会。
面试结束
后续补充:
索引失效的情况
1、like 以%开头,索引无效;当like前缀没有%,后缀有%时,索引有效
2、or语句前后没有同时使用索引。当or左右查询字段只有一个是索引,该索引失效,只有当or左右查询字段均为索引时,才会生效
3、组合索引,不是使用第一列索引,索引失效。
4、数据类型出现隐式转化。如varchar不加单引号的话可能会自动转换为int型,使索引无效,产生全表扫描。
5、在索引列上使用 IS NULL 或 IS NOT NULL操作。索引是不索引空值的,所以这样的操作不能使用索引,可以用其他的办法处理,例如:数字类型,判断大于0,字符串类型设置一个默认值,判断是否等于默认值即可。
6、在索引字段上使用not,<>,!=。不等于操作符是永远不会用到索引的,因此对它的处理只会产生全表扫描。 优化方法: key<>0 改为 key>0 or key<0
7、对索引字段进行计算操作、字段上使用函数
8、当全表扫描速度比索引速度快时,mysql会使用全表扫描,此时索引失效 (可以强制使用索引)
最后 : 谢谢小伙伴们的支持,转发,点赞,要努力过100,继续给大家带来有关面试的知识,做好不被面试官锤打的准备
面试题千变万化,为什么总是会问MySQL?的更多相关文章
- PHP訪问MySql数据库 0基础篇
在站点后台,常常要与数据库打交道.本文介绍怎样使用XAMPP来管理MySql数据库及怎样用PHP来訪问MySql数据库. 一.使用XAMPP来管理MySql数据库 首先使用XAMPP打开MySql的管 ...
- PHP的MySQL扩展:PHP訪问MySQL的经常使用扩展函数
来源:http://www.ido321.com/1024.html 一.PHP连接数据库及基本操作 MySQL採用的是'客户机/server'架构.使用PHP安装的MySQL扩展函数,和直接使用cl ...
- mysql的安装、C++訪问mysql数据库、编码设置问题
一.mysql的安装.这个相对简单,直接去官网下载mysql安装程序.就能够完毕安装过程,网上有非常多安装教程,这个没什么注意事项. 二.C++訪问mysql.主要是用到mysql定义的头文件,内部定 ...
- php訪问mysql数据库
PHP訪问Mysql数据库 PHP能够通过mysql接口和mysqli接口訪问mysql数据库. 须要加入mysql和mysqli接口才干訪问mysql数据库. windows下配置amp: a.安装 ...
- 在nginx中使用lua直接訪问mysql和memcaced达到数据接口的统一
安装nginx參见<nginx+lua+redis构建高并发应用> 让nginx 中的nginx_lua_module支持mysql 和memcache 下载 https://github ...
- 面试题Redis最常被问到知识点总结
1.什么是redis? redis是一个高性能的key-value数据库,它是完全开源免费的,而且redis是一个NOSQL类型数据库,是为了解决高并发.高扩展,大数据存储等一系列的问题而产生的数据库 ...
- InputFormat,OutputFormat,InputSplit,RecordRead(一些常见面试题),使用yum安装64位Mysql
列举出hadoop常用的一些InputFormat InputFormat是用来对我们的输入数据进行格式化的.TextInputFormat是默认的. InputFormat有哪些类型? DBInpu ...
- 面试常问MySQL性能优化问题
知识综述: [1] MySQL中锁的种类: 常见的表锁和行锁,也有Metadata Lock等等,表锁是对一整张表加锁,分为读锁和写锁,因为是锁住整张表,所以会导致并发能力下降,一般是做ddl处理时使 ...
- C语言訪问MySQL数据库的方法
1.加入头文件路径(MySQL安装路径中的include路径) 2.加入库文件(直接从MySQL安装路径中copy libmysql.lib就可以) 3.编程操作数据库 代码 // AccessToM ...
随机推荐
- loadRunnner中90%的响应时间
参考博客https://blog.csdn.net/lengyue_112/article/details/1095320?utm_source=blogxgwz4 LR在场景执行完了会出个报告,其中 ...
- 3.尚硅谷_MyBatis_HelloWorld.avi
CREATE TABLE `tbl_employee` ( `id` int(11) NOT NULL AUTO_INCREMENT, `last_name` varchar(255) DEFAULT ...
- 基于 Blazor 开发五子棋⚫⚪小游戏
今天是农历五月初五,端午节.在此,祝大家端午安康! 端午节是中华民族古老的传统节日之一.端午也称端五,端阳.此外,端午节还有许多别称,如:午日节.重五节.五月节.浴兰节.女儿节.天中节.地腊.诗人节. ...
- 腾讯IEG--2020春招实习
笔试 正常批就五道编程题,可以跳出使用本地IDE,题目很好理解,基本都能写出来,但是要过全部用例不容易.具体题目和题解可以看看这位大佬的牛客帖子,我的就不献丑了,有两题都只过了40%,我当时是用C#做 ...
- Redis高级特性
redis的事务(transaction) 转载:https://blog.csdn.net/fmwind/article/details/78065236 redis中的事务是一组命令的集合.事务同 ...
- 多图解释Redis的整数集合intset升级过程
redis源码分析系列文章 [Redis源码系列]在Liunx安装和常见API 为什么要从Redis源码分析 String底层实现——动态字符串SDS 双向链表都不懂,还说懂Redis? 面试官:说说 ...
- python之浅谈计算机基础
目录 一.计算机基础之编程 什么是编程语言 什么是编程 为什么要编程 二.计算机组成原理 1. 计算机五大组成 CPU 存储器 输入设备 输出设备 2.计算机五大部分补充 CPU相关 应用程序启动流程 ...
- Idea自带插件Groovy无法创建和启动
前言 如果现在有人要开始完全重写 Java,那么 Groovy 就像是 Java 2.0.Groovy 并没有取代 Java,而是作为 Java 的补充,它提供了更简单.更灵活的语法,可以在运行时动态 ...
- 《MapReduce: Simplified Data Processing on Large Clusters》论文研读
MapReduce 论文研读 说明:本文为论文 <MapReduce: Simplified Data Processing on Large Clusters> 的个人理解,难免有理解不 ...
- Nuxt使用axios跨域问题解决方法
Nuxt 是 Vue 项目服务器端渲染(SSR)解决方案.而在使用时,就会遇到前后端分离情况下的域名或端口不一致导致的跨域问题.本文将介绍如何通过设置代理解决 Nuxt 与 axios 集成的跨域问题 ...