点滴积累,便是进步!

  score(学生分数表):

 

  思路:要求是所有课程成绩均大于80以上的学生,则只要一门成绩小于80,就不满足条件。

          显然,只要先查出有成绩小于80的学生,然后将其排除掉,那么剩下的即为所有课程成绩都大于80的学生。

  sql:

  SELECT DISTINCT stu_id FROM score sco WHERE sco.stu_id NOT IN (SELECT DISTINCT stu_id FROM score WHERE score<80);

   ①:SELECT DISTINCT stu_id FROM score WHERE score<80 -->查询出有成绩小于80的学生;

        ②:WHERE sco.stu_id NOT IN -->使用 NOT IN 将有成绩小于80的学生排除掉;

        显然,通过①,② 两步,所得到的即为所有课程成绩都大于80的学生.

        注:DISTINCT 作用为去重

 

posted on 2017-12-29 10:08  菜大中  阅读(7852)  评论(2)    收藏  举报