TechTarget中国网站推荐

MySQL Explain详解(六)

2008-8-19  选择字号:  | |
打印本文章

  (8).index_subquery

  该联接类型类似于unique_subquery。可以替换IN子查询,但只适合下列形式的子查询中的非唯一索引:


value IN (select key_column FROM single_table where some_expr) 

  (9).range

  只检索给定范围的行,使用一个索引来选择行。key列显示使用了哪个索引。key_len包含所使用索引的最长关键元素。在该类型中ref列为NULL。

  当使用=、<>、>、>=、<、<=、IS NULL、<=>、BETWEEN或者IN操作符,用常量比较关键字列时,可以使用range


mysql> explain select * from t3 where id=3952602 or id=3952603 ; 
  +----+-------------+-------+-------+-------------------+-----------+---------+------+------+-------------+ 
  | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | 
  +----+-------------+-------+-------+-------------------+-----------+---------+------+------+-------------+ 
  | 1 | SIMPLE | t3 | range | PRIMARY,idx_t3_id | idx_t3_id | 4 | NULL | 2 | Using where | 
  +----+-------------+-------+-------+-------------------+-----------+---------+------+------+-------------+ 
  1 row in set (0.02 sec) 
  (10).index 

  该联接类型与ALL相同,除了只有索引树被扫描。这通常比ALL快,因为索引文件通常比数据文件小。

  当查询只使用作为单索引一部分的列时,MySQL可以使用该联接类型。

  (11). ALL

  对于每个来自于先前的表的行组合,进行完整的表扫描。如果表是第一个没标记const的表,这通常不好,并且通常在它情况下很差。通常可以增加更多的索引而不要使用ALL,使得行能基于前面的表中的常数值或列值被检索出。

  5.possible_keys

  possible_keys列指出MySQL能使用哪个索引在该表中找到行。注意,该列完全独立于EXPLAIN输出所示的表的次序。这意味着在possible_keys中的某些键实际上不能按生成的表次序使用。

  如果该列是NULL,则没有相关的索引。在这种情况下,可以通过检查where子句看是否它引用某些列或适合索引的列来提高你的查询性能。如果是这样,创造一个适当的索引并且再次用EXPLAIN检查查询

  6. key

  key列显示MySQL实际决定使用的键(索引)。如果没有选择索引,键是NULL。要想强制MySQL使用或忽视possible_keys列中的索引,在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。

  7.key_len

  key_len列显示MySQL决定使用的键长度。如果键是NULL,则长度为NULL。

  使用的索引的长度。在不损失精确性的情况下,长度越短越好

  8. ref

  ref列显示使用哪个列或常数与key一起从表中选择行。

  9. rows

  rows列显示MySQL认为它执行查询时必须检查的行数。

  10. Extra

  该列包含MySQL解决查询的详细信息,下面详细.

  (1).Distinct

  一旦MYSQL找到了与行相联合匹配的行,就不再搜索了

  (2).Not exists

  MYSQL优化了LEFT join,一旦它找到了匹配LEFT join标准的行,

  就不再搜索了

  (3).Range checked for each

  Record(index map:#)

  没有找到理想的索引,因此对于从前面表中来的每一个行组合,MYSQL检查使用哪个索引,并用它来从表中返回行。这是使用索引的最慢的连接之一

  (4).Using filesort

  看到这个的时候,查询就需要优化了。MYSQL需要进行额外的步骤来发现如何对返回的行排序。它根据连接类型以及存储排序键值和匹配条件的全部行的行指针来排序全部行

  (5).Using index

  列数据是从仅仅使用了索引中的信息而没有读取实际的行动的表返回的,这发生在对表的全部的请求列都是同一个索引的部分的时候

  (6).Using temporary

  看到这个的时候,查询需要优化了。这里,MYSQL需要创建一个临时表来存储结果,这通常发生在对不同的列集进行ORDER BY上,而不是GROUP BY上

  (7).Using where

  使用了where从句来限制哪些行将与下一张表匹配或者是返回给用户。如果不想返回表中的全部行,并且连接类型ALL或index,这就会发生,或者是查询有问题


MySQL Explain 详解
 MySQL Explain详解(一)
 MySQL Explain详解(二)
 MySQL Explain详解(三)
 MySQL Explain详解(四)
 MySQL Explain详解(五)
 MySQL Explain详解(六)

原文出处:http://space.itpub.net/7364032/viewspace-421320
来源:BLOG    作者:yxyup    
相关的专家答疑
MYSQL是一种小型的,紧密的数据服务器,支持标准SQL。它在UNIX和WINDOWS环境下都能够使用。
MySQLDriverCS是MySQL数据库的一个免费开源的.NET驱动程序。和Sql .NET Data Provider是为Sql Server一样,它是专门为MySQL设计的,可以叫做MySQL .NET Data Provider。
如何在.NET中访问MySQL数据库呢?也许很多人马上会说:用OLEDB嘛,但是事实上采用.NET OleDb Data Provider并不能访问MySQL,如果你使用的话,系统就会提示你……
单一文件大小有如下几个因素:1、文件系统的限制;2、某一程序进程所能存取的第一文件最大尺寸(例如apache在Linux EXT3下能存取的最大尺寸为2G,诸如日志)……
在论坛发表回复时出现“The table is full”的提示,字面意义上是数据表已满的意思。本文将以我此次问题的解决过程,介绍问题发生的原因及对策。
本篇文章主要介绍SQL Server数据存储的物理对象和原理,包括SQL Server 2005和2008里的物理数据存储、SQL Server 2008数据类型(即Datetime、字符串、自定义及等)、在SQL Server数据库中加强数据的完整性……
本文为SQL Server 2008初学者指南,主要介绍SQL Server2008 T-SQL支持的基本元素和基本操作。
本篇技术专题主要内容包括SQL Server整合、SQL Server数据库设计灾难、SQL Server数据库查询设计以及SQL Server数据库同步、复制、报告显示。
最新更新
专家答疑
技巧
Brian Peasland
我在使用这个工具的时候就出现了以上的错误。由于出现了这个错误,我就没有顺利地完成备份。你能告诉我是什么原因吗?
Rudy Limeback
我想把这些日期按照月份聚集在一起,这样我们就能查看每个售货员每个月的销售量了。我怎么才能将这些月份的日期聚集在一起呢?
Maria Anderson
我得到了一个错误信息,如“DIM-00019:创建服务错误。”我用你寄给我的解决方案解决这一问题,即:“手动创建和启动服务。”你能告诉我如何手动安装该服务吗?