第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

一個mysql group by 優(yōu)化問題

一個mysql group by 優(yōu)化問題

BIG陽 2019-04-06 08:31:34
表結(jié)構(gòu)iMoney類型:floatdtEventTime類型:datetimeiType類型:tinyintiAction類型:tinyint現(xiàn)在存在的索引(test)是:iType跟dtEventTime的一個組合索引selectsum(iMoney)asiMoney,iActionfromCostMoneywhereiType=3anddtEventTimebetween'2012-09-29'and'2012-09-30'groupbyiAction這條語句查詢后explain下idselect_typetabletypepossible_keyskeykey_lenrefrowsExtra1SIMPLECostMoneyrangetesttest9NULL3893Usingwhere;Usingtemporary;Usingfilesort這個表里面的數(shù)據(jù)每天特別大,請問有什么好的優(yōu)化辦法?
查看完整描述

2 回答

?
慕森王

TA貢獻1777條經(jīng)驗 獲得超3個贊

首先,dtEventTime必須要有索引的。而且dtEventTime類型應(yīng)該是int,不應(yīng)該使用date的。否則索引效率太低。
其次,分析這個sql的頻率高么?
如果只是幾次之類的話,而且數(shù)據(jù)要求不是實時的話,可以考慮循環(huán)取數(shù)據(jù),程序里面做group和sum的功能。
如果很頻繁,數(shù)據(jù)要求實時,只能考慮單獨對每一個iAction建立單獨的計數(shù)器。
最后,sql應(yīng)該盡量簡單,最理想的情況每次取數(shù)據(jù)都走索引。數(shù)據(jù)庫更多的是存數(shù)據(jù),盡量減少每次sql的cup和io資源。數(shù)據(jù)庫的資源很寶貴,擴展成本比較高。
                            
查看完整回答
反對 回復 2019-04-06
  • 2 回答
  • 1 關(guān)注
  • 421 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號