5

我有一个数据透视表,当然每一行都将包含在查询中:

mysql> select * from blog_posts as bp 
       join blog_joins as bj 
       on bj.post_id=1 
       and bj.taxonomy_id=10
       and bj.type = 1;

这是我的表结构:

是否建议为每一列建立索引?如果不是,为什么以及您会推荐什么?

mysql > alter table blog_joins add index pid (post_id);
mysql > alter table blog_joins add index tid (taxonomy_id);
mysql > alter table blog_joins add index tp (type);
4

2 回答 2

5

对于该特定查询,您可能会受益于多列索引:

alter table blog_joins add index pid_tid_tp (post_id,taxonomy_id,type);

我建议分析您的代码。尝试将真实数据添加到您的测试数据库并尝试一些不同的索引。用于EXPLAIN查看 MySQL 实际用于每个查询的索引。

完成测试后,删除所有未使用的索引,因为虽然索引可以加快查询速度,但它们也会减慢对表的修改。

于 2012-06-23T09:53:32.413 回答
2

您需要所有 3 列的索引

create index bjind on blog_joins (post_id, taxonomy_id, `type`);
于 2012-06-23T09:57:41.517 回答