php - 求帮助,各位大神,这条sql如何优化!!!
天蓬老师
天蓬老师 2017-04-11 10:21:04
[PHP讨论组]

1. 语句如下:

    select
    tb1.*,
    tb2.name as ad_name,
    tb3.name as media_name
    from ( 
        select 
        `day`, 
        hourly, 
        ad_id, 
        media_id, 
        count(*) AS winnotice, 
        IFNULL(SUM(cost), 0) AS cost, 
        IFNULL(budget, 0) AS budget 
        from
        pmp_report_hourly_ad 
        WHERE 1=1 
        AND `day` = '2017-03-17'
        AND status=1 
        AND type = 0 
        GROUP BY ad_id,media_id,hourly
        ORDER BY `day` DESC, hourly ASC
    ) tb1
    LEFT JOIN pmp_config_ads tb2 ON tb1.ad_id = tb2.id
    LEFT JOIN pmp_config_media tb3 ON tb3.id = tb1.media_id

2.索引如下:

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(2)
巴扎黑

好长,感觉在做阅读理解题,再贴个执行计划会更好。

看到pmp_report_hourly_ad这个表建了好多索引,而且都只覆盖一个字段,不如建一个索引,覆盖type、status、day、ad_id、media_id、hourly 。

阿神

不要用子查询的表做join操作~~查询的时候可以在表后面加上(NOLOCK),优化查询速度!

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号