ホームページ > データベース > mysql チュートリアル > 一条统计Group By语句优化

一条统计Group By语句优化

WBOY
リリース: 2016-06-07 17:36:44
オリジナル
1215 人が閲覧しました

在检查慢SQL时,发现一条统计SQL执行过慢,如下:原SQLSELECTplatform,channel,COUNT(DISTINCT(platformUserId))ascntFROM(SELECTplatform,channel,platformUser

在检查慢SQL时,,发现一条统计SQL执行过慢,如下:


原SQL

SELECT platform, channel, COUNT(DISTINCT(platformUserId)) as cnt FROM(

 SELECT platform, channel, platformUserId, MIN(insertTimestamp) as rtime

 FROM tsz_user  

 GROUP BY platform, channel, platformUserId

 ) a where a.rtime >= 1392393600 and a.rtime

 GROUP BY platform, channel;

执行时间:

wKioL1MBhMvhzpS9AAaAfFwXDUs635.jpg

耗时2分33秒


优化后SQL

SELECT platform, channel, COUNT(DISTINCT(platformUserId)) as cnt FROM(

 SELECT platform, channel, platformUserId, MIN(insertTimestamp) as rtime

 FROM tsz_user  

 GROUP BY platform, channel, platformUserId order by null

 ) a where a.rtime >= 1392393600 and a.rtime

 GROUP BY platform, channel order by null;


执行时间:

wKioL1MBhO-hysWyAAafG9IVFSM971.jpg

耗时55.22秒


执行计划:

wKioL1MBioPDXmVoAAQCe6tCaA4446.jpg


结论:

默认情况下,MySQL对所有GROUP BY col1,col2...的字段进行排序。如果查询包括GROUP BY,想要避免排序结果的消耗,则可以指定ORDER By NULL禁止排序。


参考手册:

wKioL1MBhTyynTKDAANBygQJ12k373.jpg




本文出自 “贺春旸的技术专栏” 博客,请务必保留此出处

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート