2

我一直在寻找一个好的解释,但我没有找到任何令我满意的东西。

我有这张桌子

表格电子邮件

CREATE TABLE `emails` (
  `UrlId` int(11) NOT NULL,
  `EmailAddress` varchar(100) NOT NULL,
  UNIQUE KEY `UrlId_UNIQUE` (`UrlId`,`EmailAddress`),
  CONSTRAINT `FK_UrlId_EmailAdress` FOREIGN KEY (`UrlId`) REFERENCES `urls` (`UrlId`) 
  ON DELETE CASCADE ON UPDATE NO ACTION
  ) ENGINE=InnoDB DEFAULT CHARSET=latin1;

当我运行这个查询

SELECT count(*) '# of tables',
concat(round(sum(table_rows)/1000000,2),'M') '# of rows',
concat(round(sum(data_length)/(1024*1024*1024),2),'G') 'Size of data',
concat(round(sum(index_length)/(1024*1024*1024),2),'G') 'Size of index',
concat(round(sum(data_length+index_length)/(1024*1024*1024),2),'G') 'Total size',
round(sum(index_length)/sum(data_length),2) 'Index fraction'
FROM information_schema.TABLES WHERE table_name='emails';

我得到这个结果

# of tables, # of rows, Size of data, Size of index, Total size, Index fraction
1            1.52M      0.17G         0.00G          0.17G       0.00

该表有超过 150 万行,但索引大小为 0。

然后我有这张桌子

CREATE TABLE `search_tags` (
  `TagId` int(11) NOT NULL,
  `UrlId` int(11) NOT NULL,
  UNIQUE KEY `Unique_UrlId_SearchTagId` (`UrlId`,`TagId`),
  UNIQUE KEY `Unique_SearchTagId_UrlId` (`TagId`,`UrlId`),
  CONSTRAINT `SearchTagId` FOREIGN KEY (`TagId`) REFERENCES `search_tag` (`SearchTagId`) 
  ON DELETE CASCADE ON UPDATE NO ACTION,
  CONSTRAINT `UrlId` FOREIGN KEY (`UrlId`) REFERENCES `urls` (`UrlId`) 
  ON DELETE CASCADE ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

当我在该表上运行检查查询时,我得到了这个

# of tables, # of rows, Size of data, Size of index, Total size, Index fraction
1            77.06M     3.01G         1.36G          4.37G       0.45

如您所见,我在 search_tags 表上有 2 个唯一索引。这确实显示了索引大小。

为什么索引的大小为emails0?实际数据是否也是索引,因为它是唯一的?为什么search_tags有索引大小?是因为我有双索引,并且在唯一数据的一侧创建了一个索引吗?还是我很遥远?

编辑

我决定创建一个search_tags只有 1 个唯一索引的测试表。结果和预期的一样。

# table_name       # of rows  Size of data  Size of index  Total size  Index fraction
search_tags        74.96M     3.01G         1.36G          4.37G       0.45
search_tags_test   67.92M     1.81G         0.00G          1.81G       0.00

我想可以肯定地说,覆盖整个表列的唯一索引,整个数据成为索引,因此,索引大小为 0。

然而,我过去曾说过,“可以肯定地说”......并且 100% 确定我的假设,后来发现我不正确。我只是想得到其他人的证实。

4

1 回答 1

0

它似乎是InnoDB 引擎描述的一部分:

InnoDB 表在磁盘上排列您的数据,以优化基于主键的常见查询。每个 InnoDB 表都有一个称为聚集索引的主键索引,它组织数据以最小化主键查找的 I/O。

于 2013-11-04T15:21:00.633 回答