子查询分为两种:一种是单行子查询,一种是多行子查询
1、单行子查询
单行子查询的select语句只返回一行数据,也就是说嵌入在其他Sql语句中的那个select查询值返回一行数据。...);--这里的select查询只返回一行数据
所以,我们把子查询的嵌入的select语句至返回一行数据的这类子查询,称为单行子查询
2、多行子查询
了解了单行子查询的原理,那么多行子查询自然而然的就知道了...sal from emp where deptno=30) --这里的select查询返回多行记录
执行sql之后发现和=是一样的问题,因为'>'表示一对一的关系,而子查询返回多个结果集,所以报错了...在子查询前面加上all关键字,表示当检索emp表时,只检索出哪些比(子查询结果集中最大的还要大)的数据行
所以上面的代码也可以这样表示:
select * from emp where sal>...(select max(sal) from emp where deptno=30)
3.2、多行子查询中的any操作符
在了解了all操作符之后,any操作符也就好理解了。