查找员工编号emp_no为10001的薪水涨了多少

查找员工编号emp_no为10001其自入职以来的薪水salary涨幅(总共涨了多少)growth

http://www.nowcoder.com/questionTerminal/c727647886004942a89848e2b5130dc2

1.使用MAX和MIN计算
找出来买个员工的薪水最大值和最小值,做减法,这种解法的前提是工资一直是上涨的

SELECT MAX(salary)-MIN(salary) AS growth
FROM salaries
WHERE emp_no=10001
GROUP BY emp_no

2.使用SUM
这种解法的妙处在于将历次的涨幅加在一起,但是这又有一个限制条件,就是薪水变化的日期都是连续的

select sum(s2.salary-s1.salary)
from salaries s1 , salaries s2
where s1.emp_no = 10001
and s1.to_date = s2.from_date
全部评论

相关推荐

服从性笔试吗,发这么多笔,现在还在发。
蟑螂恶霸zZ:傻 x 公司,发两次笔试,两次部门匹配挂,
投递金山WPS等公司10个岗位 >
点赞 评论 收藏
分享
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务