博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
为什么会存在using filesort
阅读量:6688 次
发布时间:2019-06-25

本文共 1443 字,大约阅读时间需要 4 分钟。

当使用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.

假设根据条件会得到两条记录Aid1uid1*)和Bid2uid2*);根据KEY `uid` (`uid`)排序规则,很容易得到这两条结果,找到的两个uid,uid1uid2,它们被检索出来的先(假如uid1)后(假如uid2)顺序已经知道了它们之间的大小关系,然而,id1id2,谁大谁小呢?不知道。必须在它们之间进行比较,如果有n条结果集,必须对它们全部取出来比较,才能知道第一个记录是哪一个。第二个,……n个呢?

  现在先来了解一下index的一个思想,假设有KEY key_name(`k1`,`k2`,……`kn`,我们知道记录集会:

 1。先按照字段k1排序,

 2。在k1相同的情况下,按k2排序,

 3。在k2也相同的情况下,再按k3排序,依此类推,

 4。最后是kn

由此规则下可知,在一个队列Lx,存在两个邻近的点Liki,1ki,2……ki,n)和Li+1ki+1,1ki+1,2……ki+1,n),如果ki,1=ki+1,1,那么知道ki,2ki+1,2在不需要比较的情况下就可以知道它们之间的关系。

所有针对以上的例子,把KEY `uid` (`uid`)修改成KEY `u_id` (`uid`,`id`)可得以解决。

但,

2select * from t_talbe where uid=1 order by id,uid;还是没办法,因为不可能建立INDEX `u_id_u` (`uid`,`id`,`uid`)

3select * from t_talbe where uid!=1 order by id;possible_keysu_f,uidkeynullextraUsing 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

转载于:https://www.cnblogs.com/xiaowangba/p/6314174.html

你可能感兴趣的文章
物联网国际标准一半以上“无锡定”
查看>>
嘉峪关市与甘肃省广电网络公司对接智慧城市建设项目
查看>>
NavigationViewController 返回到根视图
查看>>
适配器模式之享元模式
查看>>
PostgreSQL 收缩膨胀表或索引 - pg_squeeze or pg_repack
查看>>
代码实现从某个表中查询数据插入到另一个表中
查看>>
提高代码质量-工具篇
查看>>
require() 源码解读
查看>>
kvm虚拟化学习笔记(十六)之kvm虚拟化存储池配置
查看>>
★Kali信息收集~ 5.The Harvester:邮箱挖掘器
查看>>
普通web项目转化为maven web项目
查看>>
java 跳出 if
查看>>
python读取excel
查看>>
Java千百问_06数据结构(002)_java有哪8种基本数据类型
查看>>
android 内部文件读取
查看>>
Jersey REST 服务中 DELETE 请求无法接收 entity body 作为参数
查看>>
【java_web】web批量分页打印
查看>>
跟益达学Solr5之Facet一瞥
查看>>
Data truncation: Out of range value
查看>>
Java中throws和throw的区别讲解
查看>>