我有文章表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ù)。請問有更好的做法嗎?
在線等,挺急的!MySQL 如何優(yōu)化分組統(tǒng)計查詢
炎炎設(shè)計
2019-08-10 00:04:51