题解 | #获取所有非manager员工当前的薪水情况#

获取所有非manager员工当前的薪水情况

http://www.nowcoder.com/practice/8fe212a6c71b42de9c15c56ce354bebe

综合评论区的答案发现,员工表是多余的!

方法一

1、 统计所有非manager员工编号

select emp_no
    from employees 
    where emp_no not in (
        select emp_no
        from dept_manager)

2、 再根据员工id查找薪水

select de.dept_no,a.emp_no,s.salary
from (
    select emp_no
    from employees 
    where emp_no not in (
        select emp_no
        from dept_manager)
) a 
join dept_emp de on a.emp_no=de.emp_no
join salaries s on a.emp_no=s.emp_no

方法二

SELECT b.dept_no,
       b.emp_no,
       d.salary 
FROM dept_emp b,
     dept_manager c,
     salaries d 
WHERE   b.dept_no = c.dept_no 
    AND b.emp_no != c.emp_no 
    AND b.emp_no = d.emp_no
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-24 20:55
阿里国际 Java工程师 2.7k*16.0
程序员猪皮:没有超过3k的,不太好选。春招再看看
点赞 评论 收藏
分享
牛客101244697号:这个衣服和发型不去投偶像练习生?
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务