我有一个表,它有一个名为"date“的列。
这张桌子看起来像这样
CREATE TABLE IF NOT EXISTS `offers_log_archive` (
...
`date` date DEFAULT NULL,
...
KEY `date` (`date`)
) ENGINE=InnoDB
我在这个表上执行以下查询:
SELECT
*
FROM
offers_log_archive as ola
WHERE
ola.date >= "2012-12-01" and
ola.date <= "2012-12-31"
然后我做了以下事情:
explain (SELECT
*
FROM
offers_log_archive as ola
WHERE
ola.date >= "2012-12-01" and
ola.date <= "2012-12-31" );
这个解释的结果是
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE ola ALL date NULL NULL NULL 6206460 Using where
为什么我得到的是类型ALL?据我所知,这基本上意味着查询将检查表中的每一行,并忽略日期的索引。虽然我希望mysql会用到这个。
这里发生了什么?为什么日期索引被忽略?
发布于 2013-01-15 22:04:18
您的列中几乎所有的值都在查询的范围内,因此索引不仅无用(它几乎没有什么价值),而且使用索引实际上比执行简单的表扫描要昂贵得多。
编辑
首先尝试在表上运行ANALYZE
:
ANALYZE TABLE MYTABLE
如果这样还不起作用,可以尝试将语法更改为使用BETWEEN
WHERE ola.date BETWEEN '2012-12-01' AND '2012-12-31'
https://stackoverflow.com/questions/14338764
复制相似问题