数据库SQL实践27:给出每个员工每年薪水涨幅超过5000的员工编号emp_no

思想:

题目要求给出每个员工每年薪水涨幅超过5000的员工编号emp_no、薪水变更开始日期from_date以及薪水涨幅值salary_growth,并按照salary_growth逆序排列。

提示:在sqlite中获取datetime时间对应的年份函数为strftime('%Y', to_date)

首先通过条件将s1表和s2以员工号相等相连

其次通过条件将s2.salary-s1.salary大于5000的记录找出来

再者判断是否相隔一年(此时按to_date相减等于1来判断的)

最后排序

select s2.emp_no, s2.from_date, (s2.salary - s1.salary) as salary_growth
from salaries as s1, salaries as s2
where s1.emp_no = s2.emp_no
and s2.salary - s1.salary > 5000
and strftime('%Y',s2.to_date) - strftime('%Y',s1.to_date) = 1
order by salary_growth desc;

猜你喜欢

转载自blog.csdn.net/weixin_43160613/article/details/84099884
今日推荐