题解 | 查找在职员工自入职以来的薪水涨幅情况

查找在职员工自入职以来的薪水涨幅情况

https://www.nowcoder.com/practice/fc7344ece7294b9e98401826b94c6ea5

先创建两张表:
	1.初始工资表:用hire_date = from_date作为表连接条件来筛选,工资合同开始日期为该员工进公司的第一天,即该员工在公司最初的工资
	2.当前工资表:用WHERE to_date = '9999-01-01'作为条件,筛选出在职员工的最新合同
接着连接两张表,用当前工资-初始工资,即可得出在职员工的薪资涨幅总和

WITH start as (
    SELECT 
        e.emp_no,
        salary
    FROM
        employees e 
        JOIN salaries s ON e.emp_no = s.emp_no AND e.hire_date = s.from_date
),
current as (
    SELECT
        emp_no,
        salary
    FROM 
        salaries
    WHERE 
        to_date = '9999-01-01'
) 
SELECT 
    s.emp_no,
    c.salary - s.salary as growth
FROM 
    start s JOIN current c USING(emp_no)
ORDER BY 
    growth

全部评论

相关推荐

渐好:软光栅真的写明白了吗,既然是软渲那技术栈不应该使用OpenGL,光追和bvh既不算什么高级渲染技术更不应该属于软渲的内容,git那个项目没啥用,建议把前两个项目重新组织一下语言,比如软渲染那个项目 冯着色和msaa、贴图这几项分开写,写的到位点,如果你还学过光追那就单独写出来,如果没把握考官问你答不上来就别写给自己找麻烦,在技术栈那一栏简单提一下自己学过就行,这样杂的放在一起不太严谨,个人愚见.
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务