Mysql索引失效

避免索引失效的原则:

  1. 复合索引:
    复合索引不要跨列使用,尽量不要无序使用;尽量使用全索引匹配
  2. 不要在索引上进行任何操作(计算,函数,类型转换),否则索引失效
  3. like尽量以“常量”开头,不要以%开头,否则索引失效
    在这里插入图片描述
  4. 尽量不要使用类型转换(显示,隐式),否则索引失效
    在这里插入图片描述

一些其他的优化方法:

1、exists 和 in
如果主查询的数据集大,则使用in;
如果子查询的数据集大,则使用exists。
exists语法:将主查询的结果放到子查询结果中进行条件校验(看子查询是否有数据,如果有数据,则校验成功),如果符合校验,则保留数据。
2、order by 优化
using filesort 有两种算法:双路排序和单路排序(IO次数)
MySQL4.1之前使用双路排序,扫描2次磁盘;
1,从磁盘读取排序字段到内存,然后在内存中对排序字段进行排序;
2,扫描其他字段
MySQL4.1之后使用单路排序,扫描1次磁盘,读取全部字段。当数据量特别大时,会进行分片(多次)读取。单路排序比双路排序会占用更多的buffer,如果数据量太大,可以考虑调大buffer(缓存)的容量大小。
设置buffer大小:set max_length_for_sort_data = 1024; 单位是字节byte
如果max_length_for_sort_data值太低(需要排序的列的总大小大于改值),MySQL会自动从单路变成双路。
提高order by查询的策略:
a、选择使用单路,双路;调整buffer的容量大小;
b、避免使用select * …
c、复合索引不要跨列使用,避免using filesort
d、保证全部的排序字段,排序的一致性(都是升序或降序)

SQL排序-- 慢查询日志

MySQL提供的一种日志记录,用于记录MySQL中响应时间超过阀值的SQL语句(long_query_time,默认10秒)
检查是否开启了慢查询日志:show variables like ‘%slow_query_log%’;
在这里插入图片描述
临时开启:set global slow_query_log = 1;
在这里插入图片描述
慢查询阀值(时间):show variables like ‘%long_query_time%’;
设置阀值(时间):set global long_query_time = 4; --重新登录才生效
1、慢查询的SQL被记录在了日志中,因此可以通过日志查看
cat tanhqdeMacBook-Pro-slow.log
2、通过mysqldumpslow工具查看慢SQL
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值