查询和“s001”号的同学学习的课程完全相同的其他同学学号和姓名

逻辑:

如果一个人所选课程有s001选择的课程,

且没有选择与s001不同的课程,

且和s001选择的课程数量相同,

这个人还不是s001,那这个人选择的课程和s001一样。

表sc(sno 学号,cno 课程编号,score 分数)

表student(sno 学号,sname 姓名,sage 年龄,ssex 性别)

SELECT S.SNO, S.SNAME
  FROM (SELECT SC1.SNO
          FROM (SELECT SC.*
                  FROM SC
                 WHERE SC.CNO IN
                       (SELECT SC.CNO FROM SC WHERE SC.SNO = 's001') --s001选的课程
                   AND SC.CNO NOT IN
                       (SELECT SC.CNO FROM SC WHERE SC.CNO NOT IN (SELECT SC.CNO FROM SC WHERE SC.SNO = 's001')) --s001没有选的课程
                   AND SC.SNO != 's001') SC1 --不是s001 
         GROUP BY SC1.SNO
        HAVING COUNT(DISTINCT(SC1.CNO)) = (SELECT COUNT(DISTINCT(SC.CNO)) FROM SC WHERE SC.SNO = 's001'  GROUP BY SC.SNO)) SC2 --和s001选择的课程相同
  JOIN STUDENT S
    ON S.SNO = SC2.SNO;

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值