关于SQL优化的问题

SELECT SUM(`amount`) as amount, from_unixtime(`visitTime`, '%Y-%m-%d %H:00') as time FROM bfT.tj_page_3_201401 WHERE `visitTime` >= 1390194000 and `visitTime` < 1390366800 GROUP BY time

弱弱的问下,这个SQL有什么好的优化方案么,这个表的数据量在百万级别。
请输入图片描述

阅读 3.6k
2 个回答

如果你不 group by 那么在 visitTime 上建立索引就是有效的,但是这种 group by 。。。

我只想到一种办法:先预处理 visitTime 得到 time ,作为表的一个字段保存下来,然后建立 (visitTime, time) 的复合索引。

通过SQL语句可以看到的简单优化是 visitTime 建索引

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题