为什么会存在using filesort
当使用explain分析SQL时常常会遇到extra的其中一值为using
filesort,如:
PRIMARY KEY (`id`),
KEY `uid` (`uid`)
explain select * from t_talbe where uid=1order by id;
extra结果为:Using
where; Using filesort
手册中对Using filesort解释是“MySQLmust
do an extra pass to find out how to retrieve the rows in sorted order. Thesort is done by going through all rows according to the join type and storingthe sort key and pointer to the row for all rows that match the WHERE clause.”。
假设根据条件会得到两条记录A(id1,uid1,*)和B(id2,uid2,*);根据KEY
`uid` (`uid`)排序规则,很容易得到这两条结果,找到的两个uid,即uid1和uid2,它们被检索出来的先(假如uid1)后(假如uid2)顺序已经知道了它们之间的大小关系,然而,id1和id2,谁大谁小呢?不知道。必须在它们之间进行比较,如果有n条结果集,必须对它们全部取出来比较,才能知道第一个记录是哪一个。第二个,……第n个呢?
现在先来了解一下index的一个思想,假设有“KEY
key_name(`k1`,`k2`,……,`kn`)”,我们知道记录集会:
1。先按照字段k1排序,
2。在k1相同的情况下,按k2排序,
3。在k2也相同的情况下,再按k3排序,依此类推,
4。最后是kn。
由此规则下可知,在一个队列Lx中,存在两个邻近的点Li(ki,1,ki,2,……,ki,n)和Li+1(ki+1,1,ki+1,2,……,ki+1,n),如果ki,1=ki+1,1,那么知道ki,2和ki+1,2在不需要比较的情况下就可以知道它们之间的关系。
所有针对以上的例子,把KEY `uid` (`uid`)修改成KEY
`u_id` (`uid`,`id`)可得以解决。
但,
例2。select
* from t_talbe where uid=1 order by id,uid;还是没办法,因为不可能建立INDEX
`u_id_u` (`uid`,`id`,`uid`);
例3。select
* from t_talbe where uid!=1 order by id;(possible_keys:u_f,uid;key:null;extra:Using
where; Using filesort。)
其中:uid=2(id|1,2,3,4),和uid=3(id|1,2,3,4),为了得到id的排序,对于`u_id`(`uid`,`id`)还得把所有记录取出来比较。
顺便说一下,有时候存在Using filesort,也未必是什么大不了的:如
例4。
select * from t_talbe order by id;只是告诉你它使用了“all
rows”。
为什么会存在using filesort的更多相关文章
- filesort是通过相应的排序算法
filesort是通过相应的排序算法,将取得的数据在max_length_for_sort_data的默认值是1024. --------------------------------------- ...
- 在Mysql中Using filesort代表什么意思?
在Mysql中使用explain来查看sql执行信息时,经常会看到Using filesort.那么Using filesort在MySQL中代表什么意思呢? 有人会说是外部排序,其实是不对或者不准确 ...
- filesort是什么意思?
我们碰到有order by 或者group by,或者distinct语句的时候,如果查看执行计划,通常会看到using filesort的字眼,那么这个filesort是不是真是文件排序呢?其实不然 ...
- Mysql之EXPLAIN显示using filesort
索引使用经验: 1. 一条 SQL 语句只能使用 1 个索引 (5.0-),MySQL 根据表的状态,选择一个它认为最好的索引用于优化查询 2. 联合索引,只能按从左到右的顺序依次使用 Using w ...
- order by优化--Order By实现原理分析和Filesort优化
在MySQL中的ORDER BY有两种排序实现方式: 1.利用有序索引获取有序数据 2.文件排序 在使用explain分析查询的时候,利用有序索引获取有序数据显示Using index.而文件排序显示 ...
- 优化MYSQL FILESORT
用Explain分析SQL语句的时候,经常发现有的语句在Extra列会出现Using filesort,根据mysql官方文档对他的描述: 引用 MySQL must do an extra pass ...
- MySQL filesort优化案例一则
今天遇到一个filesort优化的案例,感觉不错,分享出来. MySQL中filesort是什么意思?官方手册定义: MySQL must do an extra pass to find out h ...
- 【MySQL】filesort.cc 源代码阅读笔记
最近阅读了部分MySQL排序的代码,把心得记录一下. 参考代码 MySQL: 文件: filesort.cc 函数: filesort() 排序过程伪代码 function filesort(tabl ...
- mysql filesort 的解决方案
在explain我们所使用的sql的时候,经常会遇到using filesort这种情况,原以为是由于有相同列值的原因引起,结果昨天看到公司的一个sql,跟同事讨论了下加上自己又做了一些测试,突然发现 ...
随机推荐
- git报错:'fatal:remote origin already exists
git报错:'fatal:remote origin already exists'怎么处理?附上git常用操作以及说明. git添加远程库的时候有可能出现如下的错误, 怎么解决? 只要两步: 1 ...
- 一个使用 Web Components 的音乐播放器: MelodyPlayer
先上效果预览: Web Components 首先,什么是 Web Components ? MDN 给出的定义是: Web Components 是一套不同的技术,允许您创建可重用的定制元素(它们的 ...
- C++/C# 开发高级案例资料一次送!关注加群领取哦!
目前C/C++.C#.JAVA等语言开发的在线教育比较火爆,但小编所见的讲解高级案例的非常少,切合市场需求的较少.而且针对铁路.公路.建筑.市政.制造业等所有工业计算机辅助设计的开发技术和案例几乎没有 ...
- weblogic静默方式创建域
创建域目录:mkdir -p /home/weblogic/Oracle/Middleware/user_projects/domains/base_domain/ 创建文件: create_doma ...
- JavaScript Math(算数)对象
Math 对象 Math(算数)对象的作用是:执行普通的算数任务. Math 对象提供多种算数值类型和函数.无需在使用这个对象之前对它进行定义. 使用Math的属性/方法的语法: var x=Math ...
- mysql5.7在centos上安装的完整教程以及相关的“坑”
安装前的准备 Step1: 如果你系统已经有mysql,如一般centos自带mysql5.1系列,那么你需要删除它,先检查一下系统是否自带mysql yum list installed | gre ...
- git 同步勾子
#!/bin/bash git --git-dir=/var/www/domain/.git --work-tree=/var/www/domain pull uwsgi --reload /tmp/ ...
- log4j日志记录级别是如何工作?
级别p的级别使用q,在记录日志请求时,如果p>=q启用.这条规则是log4j的核心.它假设级别是有序的.对于标准级别它们关系如下:ALL < DEBUG < INFO < WA ...
- Swagger API接口管理
介绍 Swagger API框架,用于管理项目中API接口,属当前最流行的API接口管理工具. Swagger功能强大,UI界面漂亮,支持在线测试等! Swagger包 ...
- Python descriptor
class A: def __init__(self, name): self.name = name def __get__(self, ins, cls): print('call get') i ...