Group by 未加索引
- 使用的是临时表,加文件排序(数据量小用内存排序)
加个索引(一般是联合索引)
- 注意:这里加的索引一般不会仅仅是group by后面的字段索引(大多数多少条件是一个以该字段开头联合索引,方便使用覆盖索引或者索引下推)。如果该字段是一个varchar类型,最好加个int冗余字段,建立索引的字段,性能更高。
- 以该字段为条件的B+树自动排序,所以就会导致避免了排序和临时表这个过程,查询性能更快。
加了索引还是慢(查询结果的数据量太大)?
在读多写少场景:
-
加个查询条件的统计表(Group by, order by 还是 count查询性能都不会太差)!!!!
-
每次关联的表发生变化,就更新统计表。
-
为了性能同时可以用缓存或者ES通过订阅同步该统计表。