首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用左联接检索复杂结果

使用左联接检索复杂结果
EN

Stack Overflow用户
提问于 2014-09-04 11:35:02
回答 1查看 33关注 0票数 2

我有这四张桌子

代码语言:javascript
复制
1. course 
------------------------ 
CourseID   CourseNum    CourseName             

2. courseRequirements
------------------------
CourseID  ReqID                

3. semestercourses
------------------------
CourseID                

4. studentcoursecomplete
-----------------------
CourseID   StudentID               

这句话一定要写下来

1-显示表课程中的课程名称,其中course.CourseID=semestercourses.CourseID

2-不要显示学生完成“学生课程”的课程

3-不要显示有学生未完成的要求的课程--显示有要求的课程

示例

这学期有3门课程(英语2门,数学课,体育课)。

约翰是个学生

他完成了数学课程(学生课程)

英语2有一个要求“英语1"(courseRequirements),他没有完成english1 (学生课程),如果他完成了英语1,英语2将显示

所以他可以看到“数学”课程

我有一份声明

代码语言:javascript
复制
SELECT course.*
FROM course
LEFT JOIN studentcoursecomplete ON studentcoursecomplete.CourseID = course.CourseID
LEFT JOIN courseRequirements ON courseRequirements.CourseID = course.CourseID
WHERE courseRequirements.CourseID IS NULL
    AND studentcoursecomplete.CourseID IS NULL

这个陈述很好,但是如果学生完成了english1,english2没有显示

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-04 12:16:15

我看不出你正在纳入目前宣布的课程,为给定的学期。以数据库结构为基础,下面的查询将产生您所描述的预期效果。

代码语言:javascript
复制
SELECT c.* FROM semestercourses AS sc
    LEFT JOIN course AS c ON sc.CourseID = c.CourseID
    LEFT JOIN courserequirements AS cr ON cr.ReqID = c.CourseID
    LEFT JOIN studentcoursecomplete AS scc ON scc.CourseID = c.CourseID
WHERE 
    scc.CourseID IS NULL

虽然前提条件没有得到满足,但课程已经宣布,但它是不可见的。如果它被宣布并且满足了前提条件,并且上层课程还没有完成,那么它是可见的。在这个例子中完成'English 1‘,如果英语2被宣布(在semestercourses中),那么它对你是可见的。

**编辑:

代码语言:javascript
复制
SELECT c.* FROM semestercourses AS sc
    LEFT JOIN course AS c ON c.CourseID = sc.CourseID
    LEFT JOIN courserequirements AS cr ON cr.CourseID = sc.CourseID
    LEFT JOIN studentcoursecomplete AS scc ON scc.CourseID = sc.CourseID
WHERE 
    sc.CourseID NOT IN (SELECT CourseID FROM studentcoursecomplete)
        AND 
    (cr.ReqID IS NULL OR cr.ReqID IN (SELECT CourseID FROM studentcoursecomplete))

好吧,在对数据再运行几个测试之后做了一些修改。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25664447

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档