哈哈哈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条)

报告相同问题?

悬赏问题

  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题