帮忙看看,怎么简化这条mysql语句,并且优化查询效率~~~~~

WBOY
發布: 2016-06-23 14:39:49
原創
895 人瀏覽過

本帖最后由 setoy 于 2013-12-19 12:03:34 编辑

有三张表:管理员表,部门表,和管理员对部门的打分表,如下:


现在要对每个部门的得分情况进行查询并统计,即使某个部门没有得分纪录也要显示他的得分(0分),查询统计的结果如下所示:


mysql语句一直一知半解,东拼西凑写了一段:
select   '' as type,   `class`.`name` as cname,   `score`.`cid`,   `score`.`uid`,   `user`.`name` as uname,  `score`from `score`right join `class` on `score`.`cid` = `class`.`cid`left join `user` on `score`.`uid` = `user`.`uid`union all(  select     '汇总',     `c`.`cname`,     `c`.`cid`,     `c`.`uid`,     count(`cid`) as uname,    sum(`score`) as score  from (    select       '' as type,       `class`.`name` as cname,       `score`.`cid`,       `score`.`uid`,       `user`.`name` as uname,      `score`    from `score`    right join `class` on `score`.`cid` = `class`.`cid`    left join `user` on `score`.`uid` = `user`.`uid`  ) c group by `cname`)order by `cname` asc, `type` asc;
登入後複製


貌似这个sql语句太复杂了!能不能简化这条语句呢?另外从查询效率上能不能优化?
表结构、数据和代码都在这里: http://sqlfiddle.com/#!2/6f5db6/10
请帮忙看看

回复讨论(解决方案)

可以用一句简单的sql + 一段php程序进行实现吗 

desc sql
对关键字段,加上索引看看

desc sql
对关键字段,加上索引看看 能具体点么?

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板