gpt4 book ai didi

MySQL 在索引 TIMESTAMP 列上使用文件排序

转载 作者:可可西里 更新时间:2023-11-01 07:59:29 24 4
gpt4 key购买 nike

我有一个表拒绝使用索引,它总是使用文件排序。

表格是:

CREATE TABLE `article` (  `ID` int(11) NOT NULL AUTO_INCREMENT,  `Category_ID` int(11) DEFAULT NULL,  `Subcategory` int(11) DEFAULT NULL,  `CTimestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,  `Publish` tinyint(4) DEFAULT NULL,  `Administrator_ID` int(11) DEFAULT NULL,  `Position` tinyint(4) DEFAULT '0',  PRIMARY KEY (`ID`),  KEY `Subcategory` (`Subcategory`,`Position`,`CTimestamp`,`Publish`),  KEY `Category_ID` (`Category_ID`,`CTimestamp`,`Publish`),  KEY `Position` (`Position`,`Category_ID`,`Publish`),  KEY `CTimestamp` (`CTimestamp`),  CONSTRAINT `article_ibfk_1` FOREIGN KEY (`Category_ID`) REFERENCES `category` (`ID`)) ENGINE=InnoDB AUTO_INCREMENT=94290 DEFAULT CHARSET=utf8

查询是:

SELECT * FROM article ORDER BY `CTimestamp`;

解释是:

+----+-------------+---------+------+---------------+------+---------+------+-------+----------------+| id | select_type | table   | type | possible_keys | key  | key_len | ref  | rows  | Extra          |+----+-------------+---------+------+---------------+------+---------+------+-------+----------------+|  1 | SIMPLE      | article | ALL  | NULL          | NULL | NULL    | NULL | 63568 | Using filesort |+----+-------------+---------+------+---------------+------+---------+------+-------+----------------+

当我删除“ORDER BY”时,一切正常。所有其他索引(子类别、位置等)在其他查询中工作正常。不幸的是,时间戳拒绝使用,即使是我的简单选择查询也是如此。我确定我在这里遗漏了一些重要的东西。

如何让MySQL使用时间戳索引?

谢谢。

最佳答案

在这种情况下,MySQL 没有使用您的索引进行排序,这是一件好事。为什么?您的表仅包含 64k 行,平均行宽约为 26 字节(如果我正确添加列大小),因此磁盘上的总表大小应约为 2MB。从磁盘读取 2MB 数据到内存(可能只需要 1-2 次磁盘操作或寻道)然后在内存中简单地执行文件排序(可能是快速排序的变体)是非常便宜的。

如果MySQL如你所愿按索引顺序检索,它必须执行64000次磁盘寻道操作,一条一条记录!这会非常非常慢。

当您可以使用索引快速跳转到大文件中的已知位置并只读取少量数据时,索引会很有用,就像在 WHERE 子句中一样。但是,在这种情况下,这不是个好主意——MySQL 也不傻!

如果您的表非常大(超过 RAM 大小),那么 MySQL 肯定会开始使用您的索引 - 这也是一件好事。

关于MySQL 在索引 TIMESTAMP 列上使用文件排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13063540/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com