MySQL一周从入门到精通Day4

索引的使用


1. 慢查询日志

MySQL的日志类型

  • 日志用于记录数据库的运行情况,以及用户对数据库执行的各类操作。发生故障,可以根据日志分析解决问题
  • 日志类型:重做/回滚/二进制/错误/慢查询/一般查询/中继日志

开启慢查询日志

  • 慢查询日志用于记录MySQL中 响应时间超过指定阈值的语句。
  • 参数:
    • slow_query_log 是否开启,
    • slow_query_log_file 存储路径,
    • long_query_time 阈值,
    • log_queries_not_using_indexes 未使用索引的查询,
    • log_output 日志存储方式,默认file
  • 可以通过命令临时设置,也可以通过修改配置永久设置

#查看是否开启慢日志
show variables like 'slow%';
#临时开启慢日志
set slow_query_log = 'ON';
#设置阈值
set long_query_time = 1;
#慢日志文件路径
show variables like '%datadir%';

实操
#登录
mysql -h localhost -u root -p
#查看是否开启慢日志
show variables like '%slow%';
#临时开启慢日志
set slow_query_log = 'ON';
//发现报错,原因是这是个全局变量
set global slow_query_log = 'ON';
#设置阈值
show varibles like '%long%';
set long_query_time = 1;

#慢日志输出到文件
show variables like '%log_output%';
#慢日志文件路径
show variables like '%datadir%';

#慢日志输出到表
use mysql;
show tables;

#模拟一个超过阈值的sql语句
select sleep(11);
//在C:\ProgramaData\sqlserver8.0\Data\mysql 根据自己的安装目录,里面的slow_log打开,会看到记录

2. 查询分析器explain

什么是explain

  • 用于查看SQL语句的执行计划。SQL语句前加explain,会显示将如何处理该语句。
  • 包括:分析表的读取顺序/ 数据读取操作类型/ 哪些索引可以使用/ 哪些索引被实际使用/ 表之间的引用/ 每张表有多少行被优化器查询

explain使用

  • 只要在SQL语句前加explain命令。
  • 比如,explain select * from employee where name ='张三' \G
  • explain select * from employee where id =1 \G
  • explain结果解析
    标红的几个比较重要

实操
#登录
mysql -h localhost -u root -p
#选择数据库
use mydb;
#查看表
show tables;
select * from employee;

#查询字段
select * from employee where name ='张三';
select * from employee where id = 5;

#我们加上explain后看一下具体过程
explain select * from employee where name ='张三';
explain select * from employee where id = 5;
//可以看出 从连接类型type 索引key 扫描行数rows 百分比filters
//都可以看出,索引查询效率更高

3. 索引的基本使用


索引及其作用

  • 一种特殊的数据结构,对数据库表中一列或者多列的值进行排序,类似图书的目录,可以提升查询效率。全表扫描效率很低

常见索引种类

  • 普通:加速查询
  • 唯一:列的值为一,允许有空值
  • 主键:特殊的唯一索引,不允许空值。一般建表自动创建主键索引
  • 复合:多列值
  • 全文索引:文本内容进行分词索引

索引的基本使用

创建索引

  • 创建普通索引create index indexName on tableName(columnName(length));
  • 创建唯一索引create unique index indexName on tableName(columnName(length));
  • 创建复合索引create index indexName on tableName(columnName1,columnName2,...);

删除索引 drop index [indexName] on tableName;
查看索引 show index from tableName;


索引的实战经验

  • 选择区分度高的列建立索引
  • 每次查询每张表只能使用一个索引
  • 避免对索引列进行计算

实操
#登录
mysql -h localhost -u root -p
#选择数据库
use mydb;
#查看表
show tables;
select * from employee;

#查看索引
show index from employee\G
//发现对主键默认建了一个索引
#查看详细信息
explain select * from employee where name = '张三' \G
//发现type为all,就是全扫描

#创建索引
create index idx_name on employee(name);
explain select * from employee where name = '张三' \G
//效率提升

#删除索引
drop index idx_name on employee;


4.复合索引前导列特性


  • 在MySQL中,如果创建了复合索引(name,salary,dept),就相当于创建了三个索引 (name),(name,salary), (name,salary,dept)。
  • 因此,我们要把常用查询条件的列放在最左边,所以又叫最佳左前缀特性

实操
#登录
mysql -h localhost -u root -p
#选择数据库
use mydb;
#查看表
show tables;
select * from employee;

#查看索引
show index from employee\G;
//发现对主键默认建了一个索引
#查看详细信息
explain select * from employee where name = '张三' \G
//发现type为all,就是全扫描

#创建复合索引
create index idx_name_salary_dept on employee(name,salary,dept);
#查询
explain select * from employee where name = '张三' \G
//效率提升,只扫描一行
explain select * from employee where name = '张三' and salary = '5000' \G
explain select * from employee where name = '张三' and salary ='5000' and dept = '部门A'\G

#部门A
explain select * from employee where dept = '部门A' \G
#薪水
explain select * from employee where salary = '5000' \G


5.覆盖索引


  • 又称索引覆盖,即select的数据列从索引中就能得到,不必读取数据行,也就是只要扫描索引就可以得到结果。
  • MySQL的查询优化器会在执行查询前判断,是否有一个索引覆盖所有的查询列
  • 不是所有类型都能作为覆盖索引,覆盖索引必须要存储索引列的值

- 如何判断使用了覆盖索引?
  • 查询分析器explainextra列可以看到 using index

实操
#登录
mysql -h localhost -u root -p
#选择数据库
use mydb;
#查看表
show tables;
select * from employee;

#查看索引
show index from employee\G
//发现复合索引,就是我们上一节建立的。name salary dept ,相当于有4个索引

#查看表信息
select * from employee;
#查询
select * from employee where name = '张三';
explain select * from employee where name = '张三' \G
//发现extra为null,没有覆盖索引

#查询id
explain select name from employee where name = '张三' \G
//发现extra为using index
explain select name from employee \G

//发现extra为using index
explain select name,sex from employee \G
//发现extra为null


  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL数据库是一种开源的关系型数据库管理系统,广泛应用于各种应用程序中。要从入门到精通MySQL数据库,您可以按照以下步骤进行学习: 1. 学习基本概念:了解关系型数据库的基本概念,包括表、字段、行、主键、外键等。掌握SQL语言的基本语法,包括创建表、插入数据、查询数据、更新数据和删除数据等操作。 2. 安装和配置MySQL:下载并安装MySQL数据库软件,并进行必要的配置。根据您的操作系统类型,可以选择适合的安装包和安装方法。 3. 学习SQL语言:深入学习SQL语言,包括数据定义语言(DDL)、数据操作语言(DML)、数据查询语言(DQL)和数据控制语言(DCL)等。掌握各种语句的使用方法和常见的函数。 4. 数据库设计和建模:学习如何设计和规划数据库结构,包括确定表结构、定义关系、创建索引等。了解各种数据类型和约束条件的使用。 5. 数据库操作:学习如何创建、修改和删除数据库、表和字段。掌握如何插入、更新和删除数据,以及查询数据并进行排序、过滤和分组等操作。 6. 数据库优化:了解数据库性能优化的方法和技巧,包括索引设计、查询优化、表结构调整等。学习如何监控和调优数据库性能,提高系统的响应速度和并发能力。 7. 高级特性和扩展:学习MySQL数据库的高级特性,如事务处理、存储过程、触发器、视图等。了解如何进行备份和恢复数据,以及故障处理和错误调试等。 8. 实践项目:通过实践项目来巩固所学知识,例如创建一个简单的博客系统或电子商务平台。在实际应用中遇到问题时,学会查找文档和寻求帮助。 9. 持续学习和探索:MySQL数据库是一个庞大而复杂的系统,持续学习和探索新的功能和技术是提升自己的关键。阅读官方文档、参与社区讨论和参加培训课程都是不错的学习途径。 通过以上步骤的学习和实践,您可以逐步掌握MySQL数据库的基本知识和技能,并不断提升自己的水平。记得多动手实践,不断积累经验才能更好地理解和掌握MySQL数据库

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值