1

我已经尝试过这个查询的不同变体,但我无法让它使用时间戳索引。我究竟做错了什么?

任何帮助将不胜感激 :)


MariaDB [alienvault]> explain extended SELECT * FROM alienvault_siem.acid_event WHERE (timestamp BETWEEN '2012-10-09 11:20:17' AND '2012-10-10 03:20:17');
+------+-------------+------------+------+---------------+------+---------+------+---------+----------+-------------+
| id   | select_type | table      | type | possible_keys | key  | key_len | ref  | rows    | filtered | Extra       |
+------+-------------+------------+------+---------------+------+---------+------+---------+----------+-------------+
|    1 | SIMPLE      | acid_event | ALL  | timestamp     | NULL | NULL    | NULL | 4481579 |    50.00 | Using where |
+------+-------------+------------+------+---------------+------+---------+------+---------+----------+-------------+
1 row in set, 1 warning (0.01 sec)

表结构:

CREATE TABLE IF NOT EXISTS `acid_event` (
  (...)
  `timestamp` datetime NOT NULL,
  (...)
  PRIMARY KEY (`id`),
  (...)
  KEY `timestamp` (`timestamp`),
  (...)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

软件:Percona 服务器

软件版本:5.5.27-28.1 - Percona Server (GPL),28.1 版

4

2 回答 2

3

可能是由以下原因引起的: - 索引的选择性不够,mysql 认为全扫描会更快 - mysql 的索引统计信息不正确

您可以检查“SHOW INDEX FROM alienvault_siem.acid_event;”的输出 您也可以尝试强制使用索引(但如果全扫描更快,则可能会很糟糕):

SELECT * FROM alienvault_siem.acid_event FORCE INDEX (`timestamp`) WHERE (timestamp BETWEEN '2012-10-09 11:20:17' AND '2012-10-10 03:20:17');
于 2012-10-17T18:43:26.370 回答
1

问题是您将日期文字作为字符串提供。

如果您使用如下str_to_date()功能

WHERE timestamp 
  BETWEEN str_to_date('2012-10-09 11:20:17','%Y-%m-%d %H:%i:%s') 
      AND str_to_date('2012-10-10 03:20:17','%Y-%m-%d %H:%i:%s') 

那么MySQL就可以使用索引了。

于 2012-10-10T05:00:59.140 回答