哈哈哈123457 2017-08-17 03:19 采纳率: 87.2%
浏览 836
已采纳

关于sql的问题 ,一个需求,不会写sql,求大神

已知四张表,第一张为用户表,里面有 小明 id为1,小红 id为2,小王 id为3, 小明 id为4, 小张 id为5这五个人。
第二张为数学作业表,通过用户id,然后用count可以获取每个用户数学作业完成总数,
第三张为语文作业表,通过用户id,然后用count可以获取每个用户语文作业完成总数,
第四张为英语作业表,通过用户id,然后用count可以获取每个用户英语作业完成总数,
现在需要获取五个用户的数学 ,语文, 英语 三门作业完成的总数,然后排出前三名,
返回给后台这三个人的姓名,和完成总数

  • 写回答

5条回答

  • 刚起步的程序猿 2017-08-17 03:40
    关注

    select 名字,数学完成数+语文完成数+英语完成数 from
    (
    select 名字,数学完成数,语文完成数,英语完成数 from
    (select id,name 名字 from table1 ) a,
    (select id, count(id) 数学完成数 from table2 group by id) b,
    (select id, count(id) 语文完成数 from table2 group by id) c,
    (select id, count(id) 英语完成数 from table2 group by id) d
    where a.id=b.id and a.id=c.id and a.id=d.id
    )
    where rownum<4 order by 2 desc;
    --大概就是这样吧

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥15 stable diffusion
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿