我有这四张桌子
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将显示
所以他可以看到“数学”课程
我有一份声明
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没有显示
发布于 2014-09-04 12:16:15
我看不出你正在纳入目前宣布的课程,为给定的学期。以数据库结构为基础,下面的查询将产生您所描述的预期效果。
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中),那么它对你是可见的。
**编辑:
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))好吧,在对数据再运行几个测试之后做了一些修改。
https://stackoverflow.com/questions/25664447
复制相似问题