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

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

在線等,挺急的!MySQL 如何優(yōu)化分組統(tǒng)計查詢

在線等,挺急的!MySQL 如何優(yōu)化分組統(tǒng)計查詢

炎炎設(shè)計 2019-08-10 00:04:51
我有文章表article,分類表sort文章表的views字段代表文章瀏覽量,sort_id代表分類id我需要在分類列表中顯示每個分類的總瀏覽量,SQL大概是這樣的:selecta.id,sum(b.views)fromsortasaleftjoinarticleasbona.id=b.sort_idgroupbya.idlimit10;實際情況比上面更復(fù)雜,數(shù)據(jù)在30萬左右,過濾條件也非常多,即使sort_id和views都加了索引,這種SQL也運(yùn)行起來特別慢。我目前的做法是先查出分類列表,然后在PHP里遍歷分類列表,在循環(huán)里單獨(dú)sum每個分類的總瀏覽量這樣速度快了一點,但是依然很慢,所以我把每條分頁的數(shù)據(jù)都緩存到了redis,只有第一次會在循環(huán)里sum數(shù)據(jù),后面都走緩存,這種做法也有缺點,就是數(shù)據(jù)并不是實時的數(shù)據(jù)。請問有更好的做法嗎?
查看完整描述

2 回答

?
叮當(dāng)貓咪

TA貢獻(xiàn)1776條經(jīng)驗 獲得超12個贊

你可以用后臺線程定時執(zhí)行統(tǒng)計任務(wù),更新redis;注意第一次啟動redis沒有可能會比較慢,最好在啟動時預(yù)熱一下;另外,對于沒有的sort_id,由于redis沒有,都回去數(shù)據(jù)庫掃,所以,對于有限的sort_id在接口上做一個判斷過濾,防止惡意訪問擊穿緩存。
                            
查看完整回答
反對 回復(fù) 2019-08-10
?
波斯汪

TA貢獻(xiàn)1811條經(jīng)驗 獲得超4個贊

摘掉LeftJoin
Selectsort_id,sum(views)
Fromarticle
GroupBysort_id
Limit10;
                            
查看完整回答
反對 回復(fù) 2019-08-10
  • 2 回答
  • 0 關(guān)注
  • 711 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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