300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > mysql查询高于部门平均工资_Oracle数据库中 查询高于自己部门平均工资的员工信息 用

mysql查询高于部门平均工资_Oracle数据库中 查询高于自己部门平均工资的员工信息 用

时间:2022-04-21 14:21:22

相关推荐

mysql查询高于部门平均工资_Oracle数据库中 查询高于自己部门平均工资的员工信息 用

展开全部

每个部门俯场碘渡鄢盗碉醛冬互大于所有人平均636f707962616964757a686964616f31333365633838工资的员工:

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 TB.BM=Temp.BM

where Salary>Temp.AvgSalary

SELECT DEPT.DNAME, EMP.ENAME, (EMP.SAL + NVL(M, 0)) AS SC

FROM EMP,

DEPT,

(SELECT DEPT.DEPTNO AS D, AVG(EMP.SAL + NVL(M, 0)) ESC

FROM DEPT, EMP

WHERE EMP.DEPTNO = DEPT.DEPTNO

GROUP BY DEPT.DEPTNO) T

WH俯场碘渡鄢盗碉醛冬互ERE EMP.DEPTNO = DEPT.DEPTNO

AND EMP.DEPTNO = T.D

AND (EMP.SAL + NVL(M, 0)) > T.ESC;

select a.empname, b.deptname ,a.salary

from emp as a,

( select d俯场碘渡鄢盗碉醛冬互eptid,deptname ,avg(salary) c from dept group by deptid,deptname ) b

where a.deptid=b.deptid

and a.salary >b.c

一、单行子查询:

1、单行子查询指在子查询中只返回单行值,这种子查询需要使用单行比较运算符,包括=、>、>=、。

2、单行子查询出现在WHERE子句中,如下所示:

3、单行子查询中有分组函数,要求分组函数返回的是单行数据。如下图为查询出薪水比本部门平均薪水高的员工信息:

4、单行子查询出现在HAVING子句中,如下图为查询出平均薪水高于部门30最高薪水的部门信息。

二、多行子查询:

如果子查询返回了多行,则主查询中的比较操作符应该使用多行比较操作符。Oracle数据库中的多行比较操作符包括IN、ALL、ANY,其中ALL和ANY不能单独使用,需要配合单行比较操作符>、>=、

1、多行子查询中使用IN:

IN后面是值的列表,只不过这里的值是子查询查出来的多个数据。如下图:

三、多行子查询中使用ANY操作符:

ANY操作符不能单独使用,必须和>、ANY表示大于列表中任何一个数据即为TRUE;

mysql查询高于部门平均工资_Oracle数据库中 查询高于自己部门平均工资的员工信息 用相关子查询怎么做啊?...

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。