MySQL Group by 优化查询 2023-11-25 12:29 由 奋斗成为牛马 发表于 #数据库 Group by 未加索引 使用的是临时表,加文件排序(数据量小用内存排序) 加个索引(一般是联合索引) 注意:这里加的索引一般不会仅仅是group by后面的字段索引(大多数多少条件是一个以该字段开头联合索引,方便使用覆盖索引或者索引下推)。如果该字段是一个varchar类型,最好加个int冗余字段,建立索引的字段,性能更高。 以该字段为条件的B+树自动排序,所以就会导致避免了排序和临时表这个过程,查询性能更快。 加了索引还是慢(查询结果的数据量太大)? 在读多写少场景: 1. 加个查询条件的统计表(Group by, order by 还是 count查询性能都不会太差)!!!! 2. 每次关联的表发生变化,就更新统计表。 3. 为了性能同时可以用缓存或者ES通过订阅同步该统计表。 热门相关:全天下都知道太子爱她 重生复仇:腹黑千金不好惹 重生复仇:腹黑千金不好惹 跟总裁假结婚的日子 厨道仙途