Mysql 议程表的最佳索引

标签 mysql optimization indexing agenda

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 中使用的每个字段建立一个索引是一个糟糕的选择...但是对于这种需求如何每个字段都可以避免索引吗? 对于复合索引,如果我做对了,我可以使用第二个字段,就像我使用索引的第一个字段一样,这是正确的吗?

谢谢大家。

最佳答案

SELECT * from agenda where id_user = '1';
INDEX(id_user)

SELECT * from agenda where start_day = CURDATE();
INDEX(start_day)

SELECT * from agenda where id_customer = 'X';
INDEX(id_customer)

这个

SELECT  *
    from  agenda
    where  type='2'
      AND  MONTH(start_day) = MONTH(CURDATE());

不是一个好的表述。更改为

SELECT  *
    from  agenda
    where  type='2'
      AND  start_day >= CONCAT(LEFT(CURDATE(), 7), '-01')
      AND  start_day  < CONCAT(LEFT(CURDATE(), 7), '-01') + INTERVAL 1 MONTH;

并添加此复合索引:INDEX(type, start_day)。还要删除 type 上的索引;它将毫无用处。

这个不能按原样优化(因为前导通配符):

SELECT  *
    from  agenda
    where  title LIKE '% closing %';

但是 FULLTEXT(title) 索引与 MATCH(title) AGAINST('+ opening' IN BOOLEAN MODE) 一起使用会很快。

More关于构建索引。

关于Mysql 议程表的最佳索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43612616/

相关文章:

python - 使用索引获取项目

sql - 按自然顺序提取生日

javascript - 将多维数组从mysql传输到php再到javascript

mysql - 导入sql文件替换为phpmyadmin

php - 将脚本函数卸载到响应后 : methods and best-practices?

c - 如何在C中选择寄存器变量?

python - 如何以 block 的形式迭代列表

python - 使用 pandas boolean 索引时出错

mysql - 无法从本地主机连接到 MySQL 服务器,但 MySQL 服务正在运行

sql - 我如何获得带有 ORDER BY 的 postgres 查询以进行仅索引扫描?