是不是只要 group by 就必定 using temp?

2019-01-15 11:15:13 +08:00
 Mac

myisam 引擎,一个很简单的 select 语句,列已加了索引

3568 次点击
所在节点    MySQL
5 条回复
glacer
2019-01-15 11:47:53 +08:00
using temp 通常只是为了排序,如果在 group by 的时候数据已经排序,那么就不需要 using temp。所以看你的索引是否能在 group by 被使用到。
Mac
2019-01-15 12:00:04 +08:00
@glacer 那是不是意味着所有 select 的列都加一个联合索引?
Ashitaka4
2019-01-15 13:56:25 +08:00
@Mac 顺序也要注意
saulshao
2019-01-15 16:03:00 +08:00
如果你经常用这个固定的 group by,后面的列都是一致的,确实应该要有联合索引,但是大部分情况下 group by 后面的列不是来自同一个表......
Mac
2019-01-15 16:47:28 +08:00
@saulshao 嗯理解了,跨表是无论如何都要建立临时表了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/527161

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX