查询中的子查询(评论请打好够不够详细)φ(* ̄0 ̄)

2021/6/27 23:26:01

本文主要是介绍查询中的子查询(评论请打好够不够详细)φ(* ̄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关键字也经常与比较运算符一起使用。

 



这篇关于查询中的子查询(评论请打好够不够详细)φ(* ̄0 ̄)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程