文章详情页
mysql - 请问这条sql如何加索引优化?
浏览:165日期:2022-06-16 14:44:55
问题描述
请问这条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.
问题解答
回答1:索引的话你需要在 排序和条件上加索引,但是你的total是sum出来的索引没法加。。。。那你只能在time上加索引
回答2:userid 是主键把,单看这一句sql,只需要userid这个主键就可以了
给time加索引运行的时候浪费内存,感觉利大于弊
coin使用了函数,加索引没意义
回答3:从性能角度看,应该创建一个索引,字段顺序为time,userid,coin这样数据库仅从索引尽可以执行这个sql语句
另外,建议附上执行计划,以及表的总数量、每天数据量等数据,方便其他人进行分析。
上一条:Mysql 事务问题下一条:MySQL数据库服务器循环插入执行速度慢
相关文章:
1. javascript - 如何判断用户切换到了当前标签页?2. 数据库 - mysql中怎样修改带点的字段名的位置?3. javascript - 在一些视频为主的h5页面中,是怎么做到获取视频缓冲进度或者说如何对video视频做预加载的4. datetime - Python如何获取当前时间5. mysql中 when then 的优化6. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?7. javascript - artTemplate 模板引擎,从后台获取到的数据就是html代码如何渲染到页面8. javascript - 使用ionic建立start一个项目的时候,总是失败。9. javascript - 在nodejs的程序里面怎么理解IO呢,如何用一段代码来说明IO10. javascript - 为什么!function foo(){}返回false,!function foo(){}()返回true?
排行榜

网公网安备