现有三个表:学生表(学生id,姓名)、课程表(课程id,课程名)、学生选课表(学生id,课程id),请问要列出所有学生的选课情况(每个学生选了多少门课,分别是什么),请写出SQL语句

本文介绍了如何使用SQL查询每个学生选修的课程数量以及具体课程名称。通过LEFT JOIN操作,分别从学生表、课程表和学生选课表中获取数据,再进行GROUP BY聚合,最后将两条查询合并成一条复杂查询,展示每个学生的选课详情。
摘要由CSDN通过智能技术生成

要求:用一条sql查出每个学生选了多少门课程,分别是什么

一、先建三张表:分别是学生表students、课程表classes、学生选课表stuclass
在这里插入图片描述在这里插入图片描述在这里插入图片描述

二、先分别查出每个学生选了多少门课程和每个学生分别选了哪些课程,sql语句

#每个学生选了多少门课程
SELECT
    s.id,
    s. NAME,
    count(*) count
FROM
    students AS s
LEFT JOIN stuclass AS sc ON s.id = sc.stu_id
GROUP BY
    s.id
# 每个学生选了哪些课程
SELECT
    stu_id,
    GROUP_CONCAT(c.classname) class
FROM
    stuclass AS sc
LEFT JOIN classes AS c ON c.id = sc.class_id
GROUP BY
    sc.stu_id

然后只要把两条sql合并成一条就可以了

SELECT
    *
FROM
    (
        SELECT
            s.id,
            s. NAME,
            count(*) count
        FROM
            students AS s
        LEFT JOIN stuclass AS sc ON s.id = sc.stu_id
        GROUP BY
            s.id
    ) a
LEFT JOIN (
    SELECT
        stu_id,
        GROUP_CONCAT(c.classname) class
    FROM
        stuclass AS sc
    LEFT JOIN classes AS c ON c.id = sc.class_id
    GROUP BY
        sc.stu_id
) b ON b.stu_id = a.id

查询结果如下:
在这里插入图片描述

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今夜大风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值