mysql - 请问这条sql如何加索引优化?
PHPz
PHPz 2017-04-17 16:06:05
[MySQL讨论组]

请问这条sql如何加索引优化?

select userid,sum(coin) as total from jiuwo_gift.user_consume where time >= '2016-11-07 20:47:27' group by userid order by total desc limit 10;

说明:数据表始终只有一个月的数据,每天会定时清除一个月之前的数据。具体场景就不说明了。这条sql对现在影响也不大,查询的数据结果会放redis缓存,不是频繁查询,查询耗时1s左右,只是想如何更好优化这个sql.

PHPz
PHPz

学习是最好的投资!

全部回复(3)
迷茫

索引的话你需要在 排序和条件上加索引,但是你的total是sum出来的索引没法加。。。。那你只能在time上加索引

PHP中文网
  • userid 是主键把,单看这一句sql,只需要userid这个主键就可以了

  • 给time加索引运行的时候浪费内存,感觉利大于弊

  • coin使用了函数,加索引没意义

黄舟

从性能角度看,应该创建一个索引,字段顺序为time,userid,coin
这样数据库仅从索引尽可以执行这个sql语句

另外,建议附上执行计划,以及表的总数量、每天数据量等数据,方便其他人进行分析。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号