「已注销」 2011-07-04 16:09
浏览 230
已采纳

[SQL相关]求一SQL的写法,和多表连接查询有关

现有这样的一种业务:
user表和courseUser表,courseUser表中记录的是user的学习进程(course和user是m:n关系),courseUser表中有外键userId字段与user表关联。

简单的说,一个user可以有多条记录在courseUser表中。现在要查出那些所有课程均通过(体现在courseUser表中一个叫passed的字段,1表示通过)的学员,为了简化问题,假设所有学员都有ABC三门课程(即所有user在courseUser表里都有三条记录)。

我之前尝试用普通的内连接查询,但结果是有误的,因为我不知道怎么在sql语句中体现“所有课程均通过”这一条件,现在实现的方式我感觉效率比较低下,就不贴出来了,小弟不才,十分感谢!

  • 写回答

1条回答

  • iteye_4938 2011-07-04 17:39
    关注

    select user_id from (
    select user_id,sum(passed) cnt from course_user group by user_id
    ) where cnt = 3

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型