2第8章子查询与高级查询本章要点:掌握在WHERE子句中使用子查询。掌握在HAVING子句中使用子查询。熟练掌握使用IN、ANY和ALL操作符实现子查询。熟练掌握关联子查询。熟练掌握嵌套子查询。掌握简单连接。熟练掌握多个表之间的内连接。熟练掌握多个表之间的外连接。了解多个表之间的交叉连接。掌握使用集合操作符实现集合查询。、UPDATE或DELETE语句内部使用SELECT语句,这个内部SELECT语句称为子查询(Subquery)。使用子查询,主要是将子查询的结果作为外部主查询的查找条件。——单行操作符和多行操作符。单行操作符:例如=、>、>=、<、<=、<>、!=。多行操作符:例如ALL、ANY、IN、EXISTS。可以把子查询分为两种类型:单行子查询和多行子查询。另外,子查询还有下面3种子类型,这3种子类型可以返回一行或多行查询结果。多列子查询:向外部的SQL语句返回多列。关联子查询:引用外部的SQL语句中的一列或多列。在关联子查询中,可以使用EXISTS和NOTEXISTS操作符。嵌套子查询:在子查询中包含有子查询。指定子查询时,需要注意以下几点:子查询需要使用括号()括起来。子查询要放在比较操作符的右边。当子查询的返回值是一个集合而不是一个值时,不能使用单行操作符,而必须根据需要使用ANY、IN、ALL或EXISTS等操作符。:SELECTcolumn_listFROMtable_nameWHEREexpressionoperator( SELECTcolumn_nameFROMtable_nameWHEREcondition GROUPBYexpHAVINGhaving);其中,在外部SELECT语句的WHERE子句中,expression用来指定一个表达式,也可以是表中的一列;operator可以是单行和多行操作符;()中的内容表示子查询内容。,可以使用FROM子句、WHERE子句、GROUPBY子句和HAVING子句等,但是有些情况下不能使用ORDERBY子句,例如在WHERE子句中使用子查询时,子查询语句中就不能使用ORDERBY子句。,可以实现对数据进行分组过滤。在HAVING子句中,如果使用子查询,那么就可以实现对子查询返回的结果根据分组进行过滤。【】对scott用户的emp表进行检索,在HAVING子句中使用子查询。获取哪些部门的员工平均工资小于全体员工的平均工资。具体如下:SQL>SELECTdeptno,AVG(sal)(sal)<(3 SELECTAVG(sal));DEPTNO AVG(SAL)---------- -------------30 。这个值列表可以是子查询的返回结果。,NOTIN执行的操作正好与IN在逻辑上相反。,如果接收子查询结果的操作符是单行操作符,那么在执行语句时,可能会出现错误提示。,使用ANY操作符,用来将一个值与一个列表中的所有值进行比较,这个值只需要匹配列表中的一个值即可,然后将满足条件的数据返回。其中,值列表可以是子查询的返回结果。在使用ANY操作符之前,必须使用一个单行操作符,例如=、>、<、<=等。【】对scott用户的emp表进行操作,获得工资大于任意一个部门的平均工资的员工信息,如下:,使用ALL操作符,用来将一个值与一个列表中的所有值进行比较,这个值需要匹配列表中的所有值,然后将满足条件的数据返回。其中,值列表可以是子查询的返回结果。在使用ALL操作符之前,必须使用一个单行操作符,例如=、>、<、<=等。【】对scott用户的emp表进行操作,获得工资大于所有部门的平均工资的员工信息,如下:参见教材P176
子查询与高级查询 来自淘豆网www.taodocs.com转载请标明出处.