CREATE TABLE IF NOT EXISTS `agenda` (
`id_agenda` int(11) NOT NULL AUTO_INCREMENT,
`id_user` int(11) NOT NULL DEFAULT '0',
`id_customer` int(11) DEFAULT NULL,
`type` int(11) NOT NULL DEFAULT '8',
`title` varchar(255) NOT NULL DEFAULT '',
`text` text NOT NULL,
`start_day` date NOT NULL DEFAULT '0000-00-00',
`end_day` date NOT NULL DEFAULT '0000-00-00',
`start_hour` time NOT NULL DEFAULT '00:00:00',
`end_hour` time NOT NULL DEFAULT '00:00:00'
PRIMARY KEY (`id_agenda`),
KEY `start_day` (`start_day`),
KEY `id_customer` (`id_customer`),
KEY `id_user` (`id_user`),
KEY `type` (`type`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 ;
让我们来看看这种情况:一个有 200 万条记录、10 个活跃用户的议程表的软件。
支持这种需求的最佳索引配置是什么:
1) 一个用户的所有约会列表。
例子:
SELECT * from agenda where id_user = '1';
2) 一天、一周或一个月的所有约会列表。
例子:
SELECT * from agenda where start_day = CURDATE();
3) 与客户 X 关联的所有约会的列表。
例子:
SELECT * from agenda where id_customer = 'X';
4) 例如一个月内所有类型 Y 约会的列表。
例子:
SELECT * from agenda where type='2' AND MONTH(start_day) = MONTH(CURDATE());
5)在标题内有一些字符串模式的所有约会的列表。
例子:
SELECT * from agenda where title LIKE '% closing %';
我在问这个问题,因为我已经阅读了很多文档,对于 WHERE 子句、ORDER BY、GROUP BY 中使用的每个字段都有一个索引是一个不好的选择……但是对于这种需求,如何避免每个字段的索引?使用复合索引,如果我做对了,我可以使用第二个字段,就像我使用索引的第一个字段一样,对吗?
谢谢大家。