欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

查询全部未修1号课程的学生姓名

更新时间: 2014-01-05 02:14:42 责任编辑: Author_N1

 

查询所有未修1号课程的学生姓名
SELECT Sname
FROM  Student
WHERE Sno NOT IN
( SELECT SC.Sno FROM SC
   WHERE SC.Sno = Student.Sno AND Cno = '1');



SELECT Sname
FROM  Student,sc
WHERE SC.Sno = Student.Sno AND Cno<>'1');



为什么第二个错了,第一个对,说一下原因,谢谢




--参考方法--
假设一个学生既选了课程1,又选了课程2,则这个学生是不应该被查询出来的,但是你的第二个sql语句中的过滤条件Cno<>'1',还是会把该学生选择进来,因为他选择了课程2,满足你的条件。而第一条sql就是正确的,他先将所有选了课程1的学生选择出来,再将除了这些学生的其他学生过滤了出来,正确。
--参考方法--
条件不是已经提示的很清楚了吗
未修的条件cno=1
--参考方法--
第二个查询 Cno<>'1'不包含未修的
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:14:42
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/7468/
本文WWW.DOC100.NET DOC100.NET版权所有。