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.   

    假设一个学生既选了课程1,又选了课程2,则这个学生是不应该被查询出来的,但是你的第二个sql语句中的过滤条件Cno<>'1',还是会把该学生选择进来,因为他选择了课程2,满足你的条件。而第一条sql就是正确的,他先将所有选了课程1的学生选择出来,再将除了这些学生的其他学生过滤了出来,正确。
      

  2.   

    条件不是已经提示的很清楚了吗
    未修的条件cno=1
      

  3.   

    第二个查询 Cno<>'1'不包含未修的