题解 | #查找排除当前最大、最小salary之后的员工的平均工资avg_salary#

查找排除当前最大、最小salary之后的员工的平均工资avg_salary

http://www.nowcoder.com/practice/95078e5e1fba4438b85d9f11240bc591

第一个方法先排除再求平均值

SELECT avg(salary)
FROM salaries
WHERE
to_date = '9999-01-01'
and
salary <>
(SELECT max(salary) FROM salaries WHERE to_date = '9999-01-01')
and
salary <>
(SELECT min(salary) FROM salaries WHERE to_date = '9999-01-01')
;

/*
1.先用where语句查找to_date = '9999-01-01'的员工中排除最大、最小salary
2.再用where取to_date = '9999-01-01' 剩下员工的平均值
*/

第二个方法

先找出to_date = '9999-01-01',求和后减去一个最大值和一个最小值,
再除以员工总数-2.

SELECT (sum(salary)-max(salary)-min(salary))/(count(salary)-2) avg_salary
FROM salaries
WHERE to_date='9999-01-01';

全部评论

相关推荐

点赞 评论 收藏
分享
找个工作&nbsp;学历是要卡的&nbsp;要求是高的&nbsp;技能不足是真的&nbsp;实习经验是0的&nbsp;简历无处可写是事实的&nbsp;钱不好赚是真的&nbsp;想躺平又不敢躺&nbsp;也不甘心躺&nbsp;怕自己的灵感和才华被掩埋甚至从未被自己发现&nbsp;又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务