文章详情页
c# - mysql 查询优化 ?
浏览:86日期:2022-06-12 17:32:02
问题描述
1、100万多条数据,求count 速度超慢,请大神看下该怎么优化下
2、代码:
SELECT COUNT(*)FROM `score`INNER JOIN `users` ON ( `score`.`UID` = `users`.`UID`)WHERE (`score`.`Score` >= 10)AND (`score`.`Score` <= 81);
3、索引
user表
问题解答
回答1:count(id) 不要 count(*)
回答2:你是左联了1个表,建议给UID加索引
回答3:统计为什么要内联表呢,如果要分组使用group by UID不是更好么
回答4:语句简单,索引正常,不应该慢,可以通过explain + 语句 把执行计划贴出来看看。另外users表结构也贴下,如果UID是users表的主键的话,则可以去掉表的连接
回答5:没看出连表的必要性,你只要统计分数段的数据数量,没看出和user表有什么不关系,直接单表count就好了
相关文章:
1. html5和Flash对抗是什么情况?2. android-studio - android studio 结巴了,有什么办法可以治好它吗?3. javascript - 求解答:实例对象调用constructor,此时constructor内的this的指向?4. java - spring-security与微信登录的问题?5. 前端 - ng-view不能加载进模板6. docker-compose 为何找不到配置文件?7. docker gitlab 如何git clone?8. javascript - angularjs怎么获取repeat里的某些$index值?9. MySQL启动错误10. Android下,rxJava+retrofit 并发上传文件和串行上传文件的效率为什么差不多?
排行榜
