首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL查询忽略where子句的索引

MySQL查询忽略where子句的索引
EN

Stack Overflow用户
提问于 2013-01-15 21:25:26
回答 1查看 1.1K关注 0票数 1

我有一个表,它有一个名为"date“的列。

这张桌子看起来像这样

代码语言:javascript
运行
复制
CREATE TABLE IF NOT EXISTS `offers_log_archive` (
                    ...
                    `date` date DEFAULT NULL,
                    ...
                    KEY `date` (`date`)
                ) ENGINE=InnoDB

我在这个表上执行以下查询:

代码语言:javascript
运行
复制
SELECT 
    *
FROM 
    offers_log_archive as ola
WHERE 
    ola.date >= "2012-12-01" and
    ola.date <= "2012-12-31"

然后我做了以下事情:

代码语言:javascript
运行
复制
explain (SELECT 
    *
FROM 
    offers_log_archive as ola
WHERE 
    ola.date >= "2012-12-01" and
    ola.date <= "2012-12-31" );

这个解释的结果是

代码语言:javascript
运行
复制
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会用到这个。

这里发生了什么?为什么日期索引被忽略?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-01-15 22:04:18

您的列中几乎所有的值都在查询的范围内,因此索引不仅无用(它几乎没有什么价值),而且使用索引实际上比执行简单的表扫描要昂贵得多。

编辑

首先尝试在表上运行ANALYZE

代码语言:javascript
运行
复制
ANALYZE TABLE MYTABLE

如果这样还不起作用,可以尝试将语法更改为使用BETWEEN

代码语言:javascript
运行
复制
WHERE ola.date BETWEEN '2012-12-01' AND '2012-12-31'
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14338764

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档