从感觉上来说,是先执行where查询符合条件的结果集,再执行order
by,把查询出来的结果集进行排序。
此问题设计到rdbms内部实现及其查询优化的问题,你执行一条sql语句时,rdbms的sql解析器会生成相应的执行树,按照执行树的顺序对底层存储的数据 *** 作,而后返回处理结果。这里先执行哪一个子句、后执行哪一个子句是有sql解析器决定的,sql解析器会给出一条它认为最优的执行树。
in 表示在一个结合内进行查询,比如 select from character where letter in ('A','B','C')。
=的作用就是一个值的比较。
但是等号也可以实现in的效果,只是写起来比较麻烦。比如上面的例子,你也可以这样写
select from character where letter='A' or letter='B' or letter='C'
两个运算符都比较常用,根据具体的情况选择吧
每个部门俯场碘渡鄢盗碉醛冬互大于所有人平均工资的员工:
Select BM,YG From TB WHERE Salary>(Select Avg(Salary) From TB)
每个部门大于所在部门所有人平均工资的员工:
Select BM,YG From TB
Join (Select BM,Avg(Salary) as AvgSalary From TB
Group By BM) As Temp
On TBBM=TempBM
where Salary>TempAvgSalary
SELECT DEPTDNAME, EMPENAME, (EMPSAL + NVL(EMPCOMM, 0)) AS SC
FROM EMP,
DEPT,
(SELECT DEPTDEPTNO AS D, AVG(EMPSAL + NVL(EMPCOMM, 0)) ESC
FROM DEPT, EMP
WHERE EMPDEPTNO = DEPTDEPTNO
GROUP BY DEPTDEPTNO) T
WH俯场碘渡鄢盗碉醛冬互ERE EMPDEPTNO = DEPTDEPTNO
AND EMPDEPTNO = TD
AND (EMPSAL + NVL(EMPCOMM, 0)) > TESC;
select aempname, bdeptname ,asalary
from emp as a,
( select d俯场碘渡鄢盗碉醛冬互eptid,deptname ,avg(salary) c from dept group by deptid,deptname ) b
where adeptid=bdeptid
and asalary >bc
一、单行子查询:
1、单行子查询指在子查询中只返回单行值,这种子查询需要使用单行比较运算符,包括=、>、>=、<、<=、<>。
2、单行子查询出现在WHERE子句中,如下所示:
3、单行子查询中有分组函数,要求分组函数返回的是单行数据。如下图为查询出薪水比本部门平均薪水高的员工信息:
4、单行子查询出现在HAVING子句中,如下图为查询出平均薪水高于部门30最高薪水的部门信息。
二、多行子查询:
如果子查询返回了多行,则主查询中的比较 *** 作符应该使用多行比较 *** 作符。Oracle数据库中的多行比较 *** 作符包括IN、ALL、ANY,其中ALL和ANY不能单独使用,需要配合单行比较 *** 作符>、>=、<、<=一起使用。
1、多行子查询中使用IN:
IN后面是值的列表,只不过这里的值是子查询查出来的多个数据。如下图:
三、多行子查询中使用ANY *** 作符:
ANY *** 作符不能单独使用,必须和>、<等比较 *** 作符一起使用。>ANY表示大于列表中任何一个数据即为TRUE;<ANY表示小于列表中的任何数据即为TRUE。具体实现如下图:
以上就是关于oracle中在in子查询语句中order by排序能否用全部的内容,包括:oracle中在in子查询语句中order by排序能否用、Oracle语句中IN和=的区别有哪些、Oracle数据库中 查询高于自己部门平均工资的员工信息 用相关子查询怎么做啊等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)