【MySQL数据库高级】索引单表优化案例

建表:
在这里插入图片描述


案例:

1.查询category_id 为1,且comments大于1的情况下views最多的article_id

EXPLAIN SELECT `id`,`author_id` FROM `article` WHERE `category_id` = 1 AND `comments`>1 ORDER BY `views` LIMIT 1;

comments>1使用后出现了索引失效,导致后面的order by 数据库又进行了filesort排序,性能太低,需要优化
在这里插入图片描述
建立索引:

CREATE INDEX id_category_id_comments_views ON article (category_id,comments,views);

在这里插入图片描述
删除索引:

DROP INDEX id_category_id_comments_views ON article;

优化
建立索引:

CREATE INDEX id_category_id_views ON article (category_id,views);
EXPLAIN SELECT `id`,`author_id` FROM `article` WHERE `category_id` = 1 AND `comments`>1 ORDER BY `views` LIMIT 1;

在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr_树先森

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值