MySQL索引初探
2021/7/22 2:08:36
本文主要是介绍MySQL索引初探,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
数据准备
测试数据的准备,使用MySQL官方示例测试数据。
MySQL 官方示例测试数据导入
如果本机安装了mysql,那么直接找到文件夹下运行命令即可。
我用的是docker,所以需要将文件夹先复制到docker中,然后进入mysql容器,然后进入我们复制的文件夹下,执行命令
Docker容器和本机之间的文件传输
验证索引的作用
我们对employees表进行操作,可以看到原始表中只有主键索引emp_no
我们查询同一条数据,一种我们不用索引,一种我们用主键索引,可以看到查询时间相差很大
通过explain来分析语句:
用emp_no去查询,可以看到我们用了主键索引
用first_name去查询,我们啥也没用,type是ALL,表示全表扫描
那么我们创建索引:ALTER TABLE employees ADD INDEX f_name(first_name, last_name)
这次再通过firstname查,速度就快了:
用explain来分析:
他的意思说我们用了f_name 这个索引。
验证最左匹配
我们建立了f_name索引,现在我们分别执行下面两个语句:
以first_name为查询条件,可以看到走索引了
以last_name为查询条件,可以看到是全表搜索
验证不等于,不包含
看到走了全表扫描
未完待续~~~
这篇关于MySQL索引初探的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-07MySQL读写分离入门:轻松掌握数据库读写分离技术
- 2024-12-07MySQL读写分离入门教程
- 2024-12-07MySQL分库分表入门详解
- 2024-12-07MySQL分库分表入门指南
- 2024-12-07MySQL慢查询入门:快速掌握性能优化技巧
- 2024-12-07MySQL入门:新手必读的简单教程
- 2024-12-07MySQL入门:从零开始学习MySQL数据库
- 2024-12-07MySQL索引入门:新手快速掌握MySQL索引技巧
- 2024-12-06BinLog学习:MySQL数据库BinLog入门教程
- 2024-12-06Binlog学习:MySQL数据库的日志管理入门教程