文章详情页
mysql - sql语句优化问题
浏览:149日期:2022-06-11 13:51:54
问题描述
select a,sum(b) from c GROUP BY a;select a from c;
假设c表数据量上百万,那怎么优化这2条数据,让执行更快。谢谢了
问题解答
回答1:没法从索引上优化,你使用group by 而且没有设定where条件,mysql已经全表读取。而且假如是上百万的数据,个人不提倡在表中直接用sum去统计每个a的总数。建议优化是这样的。1.建立定时任务和临时表、统计表2.定时读取一定量的数据,将那段数据统计信息记录到统计表中,将获取一定量数据的最后一个id值作为记录,写入临时表。下次读取时候以该id最为条件。
这样分段统计,可以满足你两个优化条件
回答2:先a字段加上索引吧
回答3:MySQL如何优化GROUP BY
回答4:建立复合索引(a,b),两个sql都会走索引扫描
另外对于统计类sql肯定是放在专门的报表库做的,定时分段统计
相关文章:
1. javascript - 在静态页面上用load 引入的页面文件问题?2. 代理 - 一个nginx需求,访问web服务时,若用户为测试用户则转发到web服务的测试版本3. javascript - webpack打包后的bundlejs文件代码不知道什么意思.4. java后台导出页面到pdf5. java - instance method中 static后的<K>是什么意思?6. css3 - css如何实现素描描边效果7. css - 关于ul的布局8. css - 如何使用 vue transition 实现 ios 按钮一样的平滑切换效果9. javascript - vue组件通过eventBus通信时,报错a.$on is not a function10. html - 哪些情况下float会失效?
排行榜
