doushen8391 2013-11-10 23:14
浏览 72
已采纳

如何从Mysql中的不同表中获取计数总数

I have three different tables for 3 different activities. The common field is user_id.

Performance:

id | user_id | date  | mark    
1  | 123     |  xx   |  20
2  | 456     |  xx   |  10
3  | 789     |  xx   |  5
4  | 123     |  xx   |  10
5  | 456     |  xx   |  10
6  | 789     |  xx   |  5

Internal Activities:

id | user_id | date  | mark    
1  | 123     |  xx   |  20
2  | 456     |  xx   |  10
3  | 789     |  xx   |  5
4  | 123     |  xx   |  10
5  | 456     |  xx   |  10
6  | 789     |  xx   |  5

Other Activities :

id | user_id | date  | mark    
1  | 123     |  xx   |  20
2  | 456     |  xx   |  10
3  | 789     |  xx   |  5
4  | 123     |  xx   |  10
5  | 456     |  xx   |  10
6  | 789     |  xx   |  5

How to fetch each user marks in all the 3 tables for and sort it in DESC. result should be like

id | user_id |  mark    
1  | 123     |   90
2  | 456     |   60
3  | 789     |   30

Thanks in advance

展开全部

  • 写回答

3条回答 默认 最新

  • doubengman2072 2013-11-10 23:54
    关注

    Try this:

    SELECT p.id, p.user_id, SUM(p.mark) FROM Performance p 
    LEFT JOIN Internal Activities ia ON p.id=ia.id
    LEFT JOIN Other Activities oa ON ia.id=oa.id 
    GROUP BY p.user_id; 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部