查询中的子查询(评论请打好够不够详细)φ(* ̄0 ̄)
作者:互联网
1.子查询
子查询是将一个查询语句嵌套在另一个查询语句中;内层查询语句的查询结果,可以为外层查询语句提供查询条件。因为在特定情况下,一个查询语句的条件需要另一个查询语句来获取。例如,现在需要从学生成绩表中查询计算机系统学生的各科成绩。那么,首先就必须知道哪些课程是计算机系学生选修的。因此,必须先查询计算机系学生选修的课程,然后根据这些课程来查询计算机系学生的各科成绩。通过子查询,可以实现多表之间的查询。子查询中可能包括IN、NOT IN、ANY、ALL、EXISTS、NOT EXISTS等关键字。子查询中还可能包含比较运算符,如'='、'!='、'>'和'<'等。
2.带IN关键字的子查询
一个查询语句的条件可能在另一个SELECT语句的查询结果中;这可以通过IN关键字来判断;例如,要查询哪些同学选择了计算机系开设的课程。先必须从课程表中查询出计算机系开设了哪些课程。然后再从学生表中进行查询。如果学生选修的课程在前面查询出来的课程中,则查询出该同学的信息。这可以用带IN关键字的子查询来实现。
3.带比较运算符的子查询
子查询可以使用比较运算符;这些比较运算符包括=、!=、>、>=、<、<=、<>等。其中,<>与!=是等价的。比较运算符在子查询时使用的非常广泛。如查询分数、年龄、价格、 收入等。
4.带EXISTS关键字的子查询
EXISTS关键字表示存在;使用EXISTS关键字时,内层查询语句不返回查询的记录。而是返回一个真假值。如果内层查询语句查询到满足条件的记录,就返回一个真值(TRUE)。否则,将返回一个假值(FALSE)。当返回的值是真值时,外层查询语句将进行查询。当返回值是假值时,外层查询语句不再进行查询或者查询不出任何记录。
5.带ANY关键字的子查询
ANY关键字表示满足其中任一条件;使用ANY关键字时,只要满足内层查询语句返回的结果中的任何一个,就可以通过该条件来执行外层查询语句。例如,需要查询哪些同学能够获得奖学金。那么,首先必须从奖学金表中查询出各种奖学金要求的最低分。只要一个同学的成绩高于不同奖学金最低分的任何一个,这个同学就可以获得奖学金。ANY关键字通常与比较运算符一起使用。
6.带ALL关键字的子查询
ALL关键字表示满足所有条件;使用ALL关键字时,只有满足内层查询语句返回的所有结果,才可以执行外层查询语句。例如,需要查询哪些同学能够获得一等奖学金。首先必须从奖学金表中查询出各种奖学金要求的最低分。因为一等奖金要求的分数最高。只有当同学的成绩高于所有奖学金最低分时,这个同学才可能获得等奖学金。ALL关键字也经常与比较运算符一起使用。
标签:语句,够不够,计算机系,查询,运算符,关键字,评论,奖学金 来源: https://blog.csdn.net/m0_58815937/article/details/118281057