猿问

一个mysql group by 优化问题

表结构iMoney类型:float
dtEventTime类型:datetime
iType类型:tinyint
iAction类型:tinyint现在存在的索引(test)是:
iType跟dtEventTime的一个组合索引selectsum(iMoney)asiMoney,iActionfromCostMoneywhereiType=3anddtEventTimebetween'2012-09-29'and'2012-09-30'groupbyiAction这条语句查询后explain下idselect_typetabletypepossible_keyskeykey_lenrefrowsExtra
1SIMPLECostMoneyrangetesttest9NULL3893Usingwhere;Usingtemporary;Usingfilesort这个表里面的数据每天特别大,请问有什么好的优化办法?
鸿蒙传说
浏览 329回答 2
2回答

拉莫斯之舞

首先,dtEventTime必须要有索引的。而且dtEventTime类型应该是int,不应该使用date的。否则索引效率太低。其次,分析这个sql的频率高么?如果只是几次之类的话,而且数据要求不是实时的话,可以考虑循环取数据,程序里面做group和sum的功能。如果很频繁,数据要求实时,只能考虑单独对每一个iAction建立单独的计数器。最后,sql应该尽量简单,最理想的情况每次取数据都走索引。数据库更多的是存数据,尽量减少每次sql的cup和io资源。数据库的资源很宝贵,扩展成本比较高。
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答